PHP7.4のインストール【AlmaLinux 8】
PHP7.4のインストールを行います。
1. 関連モジュールのインストール
(1) libmcryptのインストール
# dnf install --enablerepo=epel libmcrypt
(2) libargon2のインストール
# dnf install --enablerepo=epel libargon2
# dnf install --enablerepo=epel libargon2-devel
2. PHPのインストール
(1) php moduleの初期化
php moduleの初期化を行います。
(2) phpのインストール
dnfでインストールを行います。
# dnf module install php:remi-7.4
# dnf --enablerepo=epel,remi install php
# dnf --enablerepo=epel,remi install php-devel
3. phpのモジュールのインストール
これは任意ですが、必要なモジュールをインストールします。
# dnf install --enablerepo=remi php-mysqlnd
# dnf install --enablerepo=remi php-gd
# dnf install --enablerepo=remi php-xmlrpc
# dnf install --enablerepo=remi php-pecl-mcrypt
# dnf install --enablerepo=remi php-opcache
# dnf install --enablerepo=remi php-pecl-apcu
# dnf install --enablerepo=remi php-pecl-zip
# dnf install --enablerepo=remi php-pear
4. /etc/php.iniの編集
(1) php.iniの編集
# cp /etc/php.ini{,.default}
# vi /etc/php.ini
; Log errors to specified file. PHP's default behavior is to leave this value
; empty.
; http://php.net/error-log
; Example:
;error_log = php_errors.log
; Log errors to syslog.
;error_log = syslog
※php-fpmを利用している場合には、エラーログは「/var/log/php-fpm/www-error.log」に書き込まれます。(当初はこのファイルは存在しません。エラーが発生すると自動的に作成されます。)
「/etc/php-fpm.d/www.conf」にログファイル名が記載されています。
upload_max_filesize = 20M
date.timezone = "Asia/Tokyo"
session.gc_maxlifetime = 3600
mbstring.language = Japanese
mbstring.internal_encoding = UTF-8
mbstring.http_input = pass
mbstring.http_output = pass
(2) pearモジュールのインストール
必要に応じて、PEARのモジュールをインストールします。
【例】PEAR Mailモジュールのインストール。
# pear install -a Mail Mail_Mime
※「-a」オプションを付けると、依存ファイルもすべてインストールします。
(3) Apacheの再起動
Apacheを再起動して、PHPを有効にします。
# systemctl restart httpd.service
5. php-fpmサービスの起動
# systemctl enable php-fpm.service
# systemctl start php-fpm.service
6. HTMLページをPHPとして動作させる場合の設定
通常、HTMLページをPHPとして動作させる場合には、.htaccessに
<FilesMatch \.html$>
AddHandler application/x-httpd-php
</FilesMatch>
と記述すれば動作するはずですが、php-fpmを利用している場合には、設定が無効になる場合があります。
その場合には、以下のように設定します。
(1) .htacces
「/etc/httpd/conf.d/php.conf」において
# Redirect to local php-fpm (no mod_php in default configuration)
<IfModule !mod_php5.c>
<IfModule !mod_php7.c>
(略)
<FilesMatch \.(php|phar)$>
SetHandler "proxy:unix:/run/php-fpm/www.sock|fcgi://localhost"
</FilesMatch>
</IfModule>
</IfModule>
というような記述があります。
そこで、同様にfpmに処理を引き渡す必要があるので、以下のように.htaccessを記述します。
<FilesMatch \.html$>
SetHandler "proxy:unix:/run/php-fpm/www.sock|fcgi://localhost"
</FilesMatch>
(2) /etc/php-fpm.d/www.conf
デフォルトでは、PHPコードを実行可能なファイル拡張子が「.php」のみに制限されているため、「.html」も使用できるように設定します。
; Limits the extensions of the main script FPM will allow to parse. This can
; prevent configuration mistakes on the web server side. You should only limit
; FPM to .php extensions to prevent malicious users to use other extensions to
; exectute php code.
; Note: set an empty value to allow all extensions.
; Default Value: .php
;security.limit_extensions = .php .php3 .php4 .php5 .php7
の箇所の「security.limit_extensions」の項目を以下のように変更します。
security.limit_extensions = .php .html
php-fpmを再起動します。
# systemctl restart php-fpm.service
最終更新:2024年09月06日 10:41