サーバー

さくらのVPS3日目 PHPとMariaDBのセットアップ

上図はテストプログラム「hello.php」の結果です。

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
    PHP本体
  • php-cli
    コマンドラインからPHPプログラムを実行する
  • php-devel
    PHP拡張を構築する際のコンパイルに必要、らしい
  • php-common
    他のパッケージから利用される共通ファイル、と推測
  • php-gd
    グラフィック関係の処理に必要なライブラリ
  • php-mbstring
    日本語利用で必要なライブラリ
  • php-mysqlnd
    MySQLを利用するためのライブラリ
  • php-pdo
    ODBCドライバを利用してDBにアクセスするためのライブラリ
  • php-soap
    SOAPを利用するためのライブラリ
  • php-xml
    XMLを利用するためのライブラリ
  • php-xmlrpc
    XML-RPCプロトコルを利用するためのライブラリ

本体以外に必要と思われるのは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()を実行した際表示された画像データをコピーしました。

MariaDBのインストール

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に関して当方の備忘録が以下にありますので参考まで。

MySQL

 

記事に関して質問をいただいても回答できませのでご了承ください。