[AWS] PHP8.0のインストール 【Amazon Linux 2】
amazon-linux-extrasを利用して、PHP8.0をインストールします。
1. amazon-linux-extrasによるインストール
(1) phpのインストール
まずインストールすることのできるソフトウェアおよびバージョンを確認します。
$ sudo amazon-linux-extras | grep php
15 php7.2 available \
17 lamp-mariadb10.2-php7.2 available \
31 php7.3 available \
42 php7.4 available [ =stable ]
51 php8.0 available [ =stable ]
ここで51の「php8.0」をインストールします。
$ sudo amazon-linux-extras install php8.0
(2) php-develのインストール
$ sudo yum install --enablerepo=epel,remi,remi-php80 php-devel
2. 関連モジュールのインストール
(1) libmcryptのインストール
$ sudo yum install --enablerepo=epel libmcrypt
(2) libargon2のインストール
php-pdoをインストールする場合に必要です。
$ sudo yum install --enablerepo=epel libargon2
$ sudo yum install --enablerepo=epel libargon2-devel
3. PHPの設定
(1) PHPのモジュールのインストール
追加でPHPのモジュールをインストールします。
$ sudo yum install php-mysqlnd
$ sudo yum install php-mbstring
$ sudo yum install php-gd
$ sudo yum install php-xml
$ sudo yum install php-opcache
$ sudo yum install php-pecl-zip
$ sudo yum install php-pear
$ sudo yum install --enablerepo=remi,remi-php80 php-pecl-mcrypt
(2) php.iniの編集
$ sudo cp /etc/php.ini /etc/php.ini.default
$ sudo vi /etc/php.ini
;memory_limit = 128M
memory_limit = 512M
※搭載メモリによって、値を調整して下さい。
; 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
(4) Apacheの再起動
Apacheを再起動して、PHPを有効にします。
$ sudo systemctl restart httpd.service
(5) php-fpmサービスの起動
$ sudo systemctl enable php-fpm.service
$ sudo systemctl restart php-fpm.service
4. 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
5. composerのインストール
composerをインストールします。
# php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
# php -r "if (hash_file('sha384', 'composer-setup.php') === '756890a4488ce9024fc62c56153228907f1545c228516cbf63f885e036d37e9a59d27d63f46af1d4d07ee0f76181c7d3') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
# php composer-setup.php
# php -r "unlink('composer-setup.php');"
# mv composer.phar /usr/local/bin/composer
バージョン情報が表示されれば、正常に動作しています。
______
/ ____/___ ____ ___ ____ ____ ________ _____
/ / / __ \/ __ `__ \/ __ \/ __ \/ ___/ _ \/ ___/
/ /___/ /_/ / / / / / / /_/ / /_/ (__ ) __/ /
\____/\____/_/ /_/ /_/ .___/\____/____/\___/_/
/_/
Composer version 2.1.6 2021-08-19 17:11:08
※rootユーザでcomposerを実行すると、
「Do not run Composer as root/super user! See https://getcomposer.org/root for details Continue as root/super user [yes]?」
という警告が表示されます。
最終更新:2021年08月25日 07:53