上図はテストプログラム「hello.php」の結果です。
PHP7.1はremiリポジトリにあり、デフォルトのリポジトリ(公式リポジトリとEPELリポジトリ)には置かれていないため、remiリポジトリを利用できるようにします。
# rpm -Uvh http://rpms.famillecollet.com/enterprise/remi-release-7.rpm
PHPのインストールは、本体と合わせて拡張パッケージを指定します。次のコマンドでパッケージリストを表示、確認します。
# yum search php71
インストールを実行します。
# yum install --enablerepo=remi,remi-php71 php php-cli php-common php-devel php-gd php-mbstring php-mysqlnd php-pdo php-soap php-xml php-xmlrpc
当方が指定したパッケージは次の通りです。パッケージの内容は詳しくありませんので、とりあえず以下のパッケージを指定しました。
本体以外に必要と思われるのはphp-mbstring,php-mysqlndなのですが、他のブログとか確認しながら上記のようにしました。
次にphp.iniの設定ですが、タイムゾーン、エラー出力、エラー表示は、.htaccessファイル内で設定することにして、PHP起動時はプログラムでファイルをアップロードするときのサイズ指定だけ変更しました。
# vim /etc/php.ini upload_max_filesize = 128M
さて、モジュールモードでPHPを動作させる場合のphp.iniの設定は、.htaccessファイル内で設定できます。そこで、日付時間取り扱いのローカルタイムとエラーログ出力先を、同ファイル内に設定します。
操作しているHTMLのドキュメントディレクトリは「/var/www/html」です。
# vim /var/www/html/.htaccess php_value date.timezone "Asia/Tokyo" php_value error_log /var/log/php_error
ここまでの設定でPHPを起動すると、エラーログが出力できません。
調べてみると、どうやらSELinuxでログファイルの書き込みができるように設定しなければならないことが分かりました。
そこで、プロセスがPHPエラーをログファイルに書き込めるように、ファイルパーミションのオーナーとSELinuxのラベルを書き換えます。
# touch /var/log/php_error # chown apache:apache /var/log/php_error # chcon -t httpd_log_t /var/log/php_error
ようやく準備が整いましたので、Apacheを再起動して以下のテストプログラムを実行します。
<html> <body style="text-align:center; margin-top:70px;"> <?php echo "Hello World!<br>"; echo '<img border="0" src="" alt="PHP logo">'; ?> </body> </html>
PHPのロゴは、phpinfo()を実行した際表示された画像データをコピーしました。
WordPressが標準で利用するデータベースはMySQLです。MariaDBはMySQLの開発者が開発した互換製品で、インストールして同じように利用できるようです(利用は今回が初めてです)。
yumコマンドでインストール後、mysql_secure_installationコマンドを利用してMariaDBのrootユーザーのパスワードを設定します。
このrootユーザーはMariaDBの管理者ユーザー名で、MariaDBのユーザー管理はデータベース上でユーザー登録、アクセス管理の設定をします。
# yum install mariadb-server # systemctl start mariadb # mysql_secure_installation
yumでインストールの際、インストール時のオプションで全てyesを返すときは、yum -y install のように-yオプションを設定すればOKです。
次に、データベースで扱う文字コードをUTF-8に設定します。
mysqlコマンドでMariaDBにログインし、キャラクターセットを確認してみましょう。
# mysql -u root -p [MariaDB [(none)]> show variables like 'character_set%'; +--------------------------+----------------------------+ | Variable_name | Value | +--------------------------+----------------------------+ | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | latin1 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | latin1 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +--------------------------+----------------------------+ 8 rows in set (0.00 sec) [MariaDB [(none)]> exit;
MariaDBのデフォルトキャクターセットをlatin1からUTF-8へ変更するため、環境ファイル(/etc/my.cnf.d/server.cnf)を編集します。
下記の内容は、[] で囲われた各セクションにおいて追加設定するキャラクターセットの情報です。
# vim /etc/my.cnf.d/client.cnf [client] default-character-set=utf8 # vim /etc/my.cnt.d/server.cnf [mysql] default-character-set=utf8 [mysqld] collation-server = utf8_unicode_ci init-connect='SET NAMES utf8' character-set-server = utf8
編集が終了したらMariaDBサーバーをリスタートして、mysqlでログイン後上記コマンドを利用して再度キャラクターセットを表示して、latin1がutf8に変更されたことを確認します。
引き続いて、WordPressで利用するデータベースの作成とユーザー登録をします。なおデータベースのアクセスはローカルのみ有効とし、LANやWANなどネットワークからのアクセスはデフォルトで禁止状態になっており、PHPプログラムで利用する場合もローカルからの利用となります。
よって登録するユーザーは、ローカル接続のユーザーとします。
# mysql -u root -p mysql [MariaDB [mysql]> create database testdb; [MariaDB [mysql]> grant all privileges on testdb.* to testuser@localhost identified by 'xxx';
操作の内容はデータベース「testdb」を作成し、管理者ユーザー「testuser」をパスワード「xxx(任意)」で登録しました。
以上がWordPressのwp-config.phpに設定するデータベース名、ユーザー名、パスワードとなります。
以下参考にさせていただいたページのリンクです。
CentOSでPHPのエラーログが出力されない
CentOS7.1 64bit SELinuxによるアクセス制御
CentOS7 MariaDB インストール、及び初期設定
Setting Character Sets and Collations
MariaDBのインストールと初期設定 | CentOS 7
MySQLに関して当方の備忘録が以下にありますので参考まで。
記事に関して質問をいただいても回答できませのでご了承ください。