11
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Wordpress公式のwordpress:cliイメージを使う

Last updated at Posted at 2018-04-03

やりたいこと

Wordpressの公式コンテナを使い、Docker-composeでWPサイトを作成すると、最初にアクセスしたときに言語やサイト名、管理ユーザー名などの初期設定の画面が表示される。これらの設定も設定済みの状態にするような方法がないかというと(環境変数とかでできてもよさそうだが・・・)WordpressのCLI管理ソフトを利用してスクリプト化しておくのがいいのじゃないかという結論に至った。

library/wordpress - Docker Hub

wp-cliも上記の公式にイメージが用意されており(一番下の方)、WP本体のボリュームをマウントすることで利用できる作りになっているようだが、いくつかのタスクが、具体的には日本語の定義ファイルをDLインストールするところがうまくいかなかったのでその原因を調べてみた。

やったこと(うまくいかない現象)

Wordpressを立てる

まずは、Wordpressを普通に立てる。これはいろんな記事があり、mysqlとセットであげるようなdocker-composeを作るのが簡単。

DockerでWordPress環境を構築する - Qiita より引用すると

docker-compose.yml
version: '3.3'

services:
   db:
     image: mysql:5.7
     volumes:
       - dbdata:/var/lib/mysql
     restart: always
     environment:
       MYSQL_ROOT_PASSWORD: somewordpress
       MYSQL_DATABASE: wordpress
       MYSQL_USER: wordpress
       MYSQL_PASSWORD: wordpress

   wordpress:
     depends_on:
       - db
     image: wordpress:latest
     ports:
       - "8000:80"
     restart: always
     environment:
       WORDPRESS_DB_HOST: db:3306
       WORDPRESS_DB_USER: wordpress
       WORDPRESS_DB_PASSWORD: wordpress
volumes:
    dbdata:

wordpress:cliでアクセスする

これに対して、WP-CLIでアクセスして、設定などを行えるようにする。
wp-cliは、ssh越しやHTTP越しでも出来るようだが、Docker環境化ならば、--volumes-fromで、Wordpressコンテナのインストール先をマウントして、そこで処理するという方法を取れる。

docker run -it --rm \
    --volumes-from some-wordpress \
    --network container:some-wordpress \
    wordpress:cli  <WP-CLIのサブコマンド>

と、ここまでが、ほぼ公式通りのインタラクションと思われる。

うまくいかない。

上記のWP-CLIを利用するためのコマンドを、長いのでDOCKER_WP_CLIとエイリアスしたとして、いくつかのコマンドがうまくいかない。

うまくいかない

# install core 
$ DOCKER_WP_CLI core install --url="https://something.example.com" \
                --title="Wordpress blog" \
                --admin_user="adminadmin" \
                --admin_email="adminadmin@example.com"

Admin password: xxxxxxxx
Warning: Unable to create directory wp-content/uploads/2018/04. Is its parent directory writable by the server?
Success: WordPress installed successfully.

# install Japanese language definition
$ DOCKER_WP_CLI language core install ja
$ DOCKER_WP_CLI language core activate ja

Error: Could not create directory. "/var/www/html/wp-content/languages/"
Error: Language not installed.

日本語化が上手く言ってない。
コアの方も一件すると上手くいってそうとおもったが、Warningにあるようにメディアアップロード用のディレクトリが作れていないようだ。

原因

結論から言うと、「WPのコンテナと、WP-CLIのコンテナでwww-dataユーザーのuidが違った」ことが原因のようだ。これはWP本体のImageがDebianで作られており、wp-cliのほうはAlpineベースのため、起きていると思われる。

WP本体の方のコンテナ
$ cat /etc/passwd | grep www-data
www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin

$ cat /etc/os-release
PRETTY_NAME="Debian GNU/Linux 9 (stretch)"
NAME="Debian GNU/Linux"
()

↑ www-dataはUIDが33 ↓ UIDが82

WP-CLIのコンテナ
$ cat /etc/passwd | grep www-data
www-data:x:82:82:Linux User,,,:/home/www-data:/bin/false

$ cat /etc/os-release
NAME="Alpine Linux"
ID=alpine
()

解決方法

WPのほうもAlpineベースのコンテナを選択することで、ちゃんと動くようになる。

ところが、Alpineベースのものは、php-fpmを用いたものしかないようで、Webサーバーは同梱されていない。
なので、別途nginxのコンテナを立ててやる必要がある。

内容としては上記のそのままだが、まとめると、

docker-compose.yml
version: '3.3'

services:
   db:
     image: mysql:5.7
     volumes:
       - dbdata:/var/lib/mysql
     restart: always
     environment:
       MYSQL_ROOT_PASSWORD: somewordpress
       MYSQL_DATABASE: wordpress
       MYSQL_USER: wordpress
       MYSQL_PASSWORD: wordpress

   wordpress:
     depends_on:
       - db
     image:  wordpress:4.9.4-php7.2-fpm-alpine # Alpineにする!
     volumes:
       - wpdata:/var/www/html
     restart: always
     environment:
       WORDPRESS_DB_HOST: db:3306
       WORDPRESS_DB_USER: wordpress
       WORDPRESS_DB_PASSWORD: wordpress

  nginx:
    image: nginx
    ports:
      - 80:80
    volumes:
      - ./nginx_build/nginx.conf:/etc/nginx/nginx.conf
      - wpdata:/var/www/html

volumes:
    dbdata:
    wpdata:

./ngnx_build/nginx.conf(抜粋)
server {
    listen 80;
    server_name something.example.com;
 
    root /var/www/html;
    index index.php;
 
    access_log /var/log/nginx/hoge.log;
    error_log /var/log/nginx/hoge.log;
 
    location / {
        try_files $uri $uri/ /index.php?$args;
    }
 
    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass wordpress:9000;
        fastcgi_index index.php;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PATH_INFO $fastcgi_path_info;
    }
}

このように設定する。
こうすると、WP本体もWP-CLIもAlpineになったので、前述のwordpress:cliのコンテナの使い方で上手く行くことが確認できた。

WP本体側とwp-cli側両方を最短手番で調べると、引っかかる問題なので、ほかにも困っている人がいたら助けになるといいなー。

解決方法2

DebianのWPのほうでwww-dataのuidは33で、wp-cliのでそのuidを持っているのはxfsというユーザーだった。
なので、そのユーザー名でログインするようにしてやれば、一応動く。

$ docker run -it --rm \
    --volumes-from some-wordpress \
    --network container:some-wordpress \
    -u xfs \
    wordpress:cli core install ja

Downloading translation from https://downloads.wordpress.org/translation/core/4.9.4/ja.zip...
Unpacking the update...
Installing the latest version...

動くけどなにか気持ち悪い。

補足

ちなみに、最初、WPの本体をインストールしたときに、言語設定のが面が出ずにいきなり英語で設定が始まる場合があると思います。その場合はproxy設定などでささってないか確認すると良いです。言語設定ファイルとかがそもそもダウンロードできない状況だと英語で設定を始めるっぽい。

proxyめ・・・。

11
13
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
11
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?