Ubuntu 20.04/18.04にWordPress環境構築

Pocket

UbuntuにWordPress環境構築

  • 20.04
  • 18.04

基本的に20.04を前提に記載する。

18.04の場合は適宜読み替える。
WordPress関連では18.04は以下の違いがある。

  • PHPバージョンが7.2
  • MySQL5.7をインストール可能

以下AWS EC2を仮定するので、ほとんどsudoで実行する。
AWSの初期設定ではほとんどのコマンドをsudoをつけないと実行できない。
以下のようにrootにスイッチすることもできる(備忘録のために記載しているがrootのままでいるのは危険なので推奨はしない)。

$ sudo su -

バージョン&アーキテクチャ確認

# バージョンを確認
$ sudo cat /etc/os-release
// DISTRIB_ID=Ubuntu
// DISTRIB_RELEASE=20.04
// DISTRIB_CODENAME=focal
// DISTRIB_DESCRIPTION="Ubuntu 20.04.1 LTS"
# アーキテクチャを確認
$ sudo arch
// x86_64

パッケージインストール

apt update -y && apt upgrade -y

  1. apt update:リポジトリから有効で更新可能なパッケージ一覧を取得
  2. apt upgrade:パッケージをアップデート
$ sudo apt update -y && sudo apt upgrade -y

Ubuntu Packages Search

Ubuntu – Ubuntu パッケージ検索

登録リポジトリを確認

$ sudo cat /etc/apt/sources.list

ref. https://kujira16.hateblo.jp/entry/2019/10/14/190008

インストール済みパッケージを確認

$ sudo apt list --installed

ref. https://news.mynavi.jp/article/20190222-775519/

パッケージをインストール

  1. Ubuntu – Ubuntu パッケージ検索で対象パッケージを検索
  2. $ apt install {{package}}
Apache
$ sudo apt install apache2
PHP
$ sudo apt install php

以下のパッケージがインストールされる。

$ sudo apt list --installed | grep php

WARNING: apt does not have a stable CLI interface. Use with caution in scripts.

libapache2-mod-php7.4/focal-updates,focal-security,now 7.4.3-4ubuntu2.4 amd64 [installed,automatic]
php-common/focal,now 2:75 all [installed,automatic]
php7.4-cli/focal-updates,focal-security,now 7.4.3-4ubuntu2.4 amd64 [installed,automatic]
php7.4-common/focal-updates,focal-security,now 7.4.3-4ubuntu2.4 amd64 [installed,automatic]
php7.4-json/focal-updates,focal-security,now 7.4.3-4ubuntu2.4 amd64 [installed,automatic]
php7.4-opcache/focal-updates,focal-security,now 7.4.3-4ubuntu2.4 amd64 [installed,automatic]
php7.4-readline/focal-updates,focal-security,now 7.4.3-4ubuntu2.4 amd64 [installed,automatic]
php7.4/focal-updates,focal-security,now 7.4.3-4ubuntu2.4 all [installed,automatic]
php/focal,now 2:7.4+75 all [installed]
WordPressに必要な拡張モジュール(extnsions)をインストール

インストール済みの拡張モジュールを確認する。

$ php -m
calendar
Core
ctype
date
exif
FFI
fileinfo
filter
ftp
gettext
hash
iconv
json
libxml
openssl
pcntl
pcre
PDO
Phar
posix
readline
Reflection
session
shmop
sockets
sodium
SPL
standard
sysvmsg
sysvsem
sysvshm
tokenizer
Zend OPcache
zlib

[Zend Modules]
Zend OPcache

WordPressに必要なモジュールは以下リンクを参照。
https://make.wordpress.org/hosting/handbook/handbook/server-environment/#php-extensions

足りない拡張モジュールをインストールする。

  • curl
  • dom
  • mbstring
  • mysqli
  • imagick
  • xml
  • zip
// Ubuntu 20.04
$ sudo apt install php7.4-curl php7.4-dom php7.4-mbstring php7.4-mysqli php7.4-imagick php7.4-xml php7.4-zip

※ Ubuntu 18.04は、上記をphp7.2に置き換える(ただしphp7.4-imagickphp-imagick)。

imagickGD

WordPressの画像関連処理では、imagickがインストールされていないときはフォールバックとしてGDが使用される.

imagick – Provides better image quality for media uploads. See WP_Image_Editor is incoming! for details. Smarter image resizing (for smaller images) and PDF thumbnail support, when Ghost Script is also available.

gd – If Imagick isn’t installed, the GD Graphics Library is used as a functionally limited fallback for image manipulation.

Server Environment

Ubuntu 18.04にphp-imagckphp-gdをインストールする方法は以下のとおり。

imagickインストール

$ sudo apt install php-imagick

※バージョンを指定しない(php7.2-imagickはNG)

GDインストール

imagickがインストールできない場合にインストール。

$ sudo apt install php7.2-gd

ref. https://packages.ubuntu.com/ja/bionic/php7.2-gd

Apache再起動
$ sudo apachectl graceful

以下メッセージが表示されたら/etc/apache2.confServerName xxx.xxx.xxx.xxxxを追記。
/etc/apache2/sites-availables/000-default.confに追加してもエラーは解消されない)

sudo apachectl graceful
AH00558: apache2: Could not reliably determine the server's fully qualified domain name, using xxx.xxx.xxx.xxxx. Set the 'ServerName' directive globally to suppress this message
MySQL

Ubuntu 20.04のリポジトリにはMySQL 5.7はないが、以下を参考にインストール。
https://computingforgeeks.com/how-to-install-mysql-on-ubuntu-focal/

18.04

MySQL 5.7がインストール可能。
以下に留意。

  • MySQL 5.7はインストールした状態ではsudoなしではアクセスできない
  • セキュリティのためsudo mysql_secure_installationを実行
  • sudo無しでアクセスできるようにsudoでログインした後に以下を実行(sudo有りだとWordPressから接続するときに面倒)
mysql > ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '{{password}}';

ref. https://note.com/junf/n/na40fbca9e6ea

なにかあって、MySQLを完全に削除したいときは、以下記事を参考にする。
https://qiita.com/King_kenshi/items/b6f217a8a3083c98904b

sudo apt-get remove --purge mysql-server* mysql-common
sudo apt-get autoremove --purge
sudo rm -r /etc/mysql
sudo rm -r /var/lib/mysql
WordPressインストール
  1. 本体ダウンロード
  2. データベース作成
  3. htmlディレクトリの所有者:グループ変更
$ sudo wget https://ja.wordpress.org/latest-ja.tar.gz
$ sudo tar -xzvf latest-ja.tar.gz

WordPress用データベース作成

mysql > CREATE DATABASE <database> DEFAULT CHARACTER SET utf8mb4;

/var/www/htmlの所有者変更

$ sudo chown -R www-data:www-data /var/www/html

www-dataはUbuntu 20.04/18.04にインストールしたApacheのユーザーグループ
/etc/apache2/apache2.confに下記記載がある。

# These need to be set in /etc/apache2/envvars
User ${APACHE_RUN_USER}
Group ${APACHE_RUN_GROUP}

/etc/apache2/envvarsの記載。

export APACHE_RUN_USER=www-data
export APACHE_RUN_GROUP=www-data
WordPressテストデータ挿入
  1. wp-cliインストール
  2. wordpress-importer有効化
  3. テストデータ(wordpress-theme-test-data-ja.xml) インポート
$ sudo curl -O https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar
$ sudo chmod u+x wp-cli.phar
$ sudo mv ./wp-cli.phar /usr/bin/wp
$ cd /var/www/html/wordpress
$ sudo curl -O https://raw.githubusercontent.com/jawordpressorg/theme-test-data-ja/master/wordpress-theme-test-data-ja.xml
$ sudo wp plugin install wordpress-importer --activate
$ sudo wp import wordpress-theme-test-data-ja.xml --authors=create --allow-root

※ 上記でテストデータをインストールした場合、テストデータとして挿入されるuploads配下のファイル(およびディレクトリ)はユーザー・グループともにrootになる。
そのままでは画像編集ができないのでユーザー・グループをwww-dataに変更。

$ cd /path/to/wp-content
$ sudo chmod -R www-data uploads
$ sudo chgrp -R www-data uploads

パッケージアンインストール

Bad

$ apt remove php

Good

$ apt remove php-common

SSL化(Let’s Encrypt)

以下を例に記載。

  • Ubuntu 18.04
  • example.comドメイン

手順(概要)

  1. Apache SSLモジュール有効化(OSによってことなる)
    • Ubuntuは$ a2enmod sslで有効化
  2. Let’s Encryptで証明書作成(/etc/letsencrypt/live/exxample.com/に作成されたと仮定する`)

Let’s Encryptで証明書作成は、実際はCertbotの使用が推奨される。
Certbotを使用すれば自動で必要な設定をしてくれる。よって$ a2enmod ssl以外は以下の手順(詳細)は必要ない。

手順(詳細)

  1. $ a2enmod ssl
  2. /etc/apache2/sites-availableにバーチャルホスト用のconfファイル作成(例)example.com.conf)
  3. example.com.confにSSL用バーチャルホスト設定
  4. $ apachectl configtest
  5. $ apachectl graceful(推奨)または$ service apache2 reload

apache gracefulで上記メッセージが表示されたら/etc/apache2.confServerName xxx.xxx.xxx.xxxxを追記。
/etc/apache2/sites-availables/000-default.confに追加してもエラーは解消されない)

“`example.com.conf


ServerAdmin webmaster@localhost
ServerName example.com
DocumentRoot /var/www/html

            SSLEngine on
            SSLCertificateFile      /etc/letsencrypt/live/exxample.com/fullchain.pem
            SSLCertificateKeyFile  /etc/letsencrypt/live/example.com/privkey.pem
    </VirtualHost>


“`

コメント

No comments yet.

コメントの投稿

改行と段落タグは自動で挿入されます。
メールアドレスは表示されません。