从Sakura的租用服务器迁移到ConoHa VPS的Docker环境时,记录了WordPress迁移备忘录

首先

我打算将我在Sakura Internet托管的Wordpress迁移到ConoHa VPS。在ConoHa VPS上,我将使用Docker容器化来运行Wordpress。作为前提条件,我们假设已经运行了基于Docker的jwilder/nginx-proxy和jrcs/letsencrypt-nginx-proxy-companion,并且我将对每个域名进行迁移。关于nginx-proxy和letsencrypt-nginx-proxy-companion的配置,请参考以下相关文章。

相关: 将Mastodon实例迁移到ConoHa VPS备忘录

以下是与上述的Mastodon实例相同的构成。

nginx-proxy <--(front bridge)--> nginx <--(wordpress用back bridge)--> wordpress

在移交者和登记员的工作方面

首先,在转移前(樱花互联网租用服务器)上导出数据并调整每个域名的DNS设置,然后将其迁移到新服务器。

数据导出@原位置移动

以转移资金为例,导出的内容将包括wp-content和MySQL的转储文件。

# wp-contentのエクスポート
$ tar zcvf ~/wp-content.tar.gz <path_to_wordpress_dir>/wp-content

# MySQLのバックアップ@移行元
$ mysqldump --default-character-set=utf8 -h mysql***.db.sakura.ne.jp -u <your_mysql_id> -p<your_mysql_password> <your_db_name > ~/wordpress_mysql.sql

编辑A记录 @ 迁移源

把A记录改为目标VPS的IP地址。MX记录等设置为@会导致不一致,请注意。修改后,请暂时不要动它。

使用Wordpress开始

建立WordPress非常容易。請按照以下方式創建~/apps/wordpress/docker-compose.yml和~/apps/wordpress/setting/nginx/conf.d/default.conf。

version: '2'
services:
  nginx:
    image: nginx:alpine
    container_name: wordpress-nginx
    expose:
      - "20092" # ポートは適当に変えてOK
    restart: always
    tty: false
    environment:
      - "VIRTUAL_HOST=<your_domain>"
      - "VIRTUAL_PORT=20092"
      - "LETSENCRYPT_HOST=<your_domain>"
      - "LETSENCRYPT_EMAIL=<your_email>"
      - "LETSENCRYPT_TEST=false"
    links:
      - wordpress
    volumes:
      - ./setting/nginx/conf.d:/etc/nginx/conf.d:ro
    volumes_from:
      - container:proxy-nginx # proxy-nginxをマウントするのはletsencryptの証明書を使うため。別記事を参照のこと。
    networks:
      - front
      - back-wordpress

  wordpress:
    image: wordpress:latest
    hostname: <your_domain>
    restart: always
    container_name: wordpress
    expose:
      - "80"
    links:
      - mysql
    volumes:
      - ./data/wp-content:/var/www/html/wp-content
    environment:
      - "WORDPRESS_DB_NAME=<your_db_name>" # DB名、DB_USER名、DB_PASSWORDは移行前と異なってOK
      - "WORDPRESS_DB_USER=<your_db_user>"
      - "WORDPRESS_DB_PASSWORD=<your_db_password>"
    networks:
      - back-wordpress

  mysql:
    image: mysql:5.7
    restart: always
    container_name: wordpress-mysql
    volumes:
      - ./data/mysql:/var/lib/mysql
    environment:
      - "MYSQL_ROOT_PASSWORD=<your_db_root_passoword>"
      - "MYSQL_DATABASE=<your_db_name>"
      - "MYSQL_USER=<your_db_user>"
      - "MYSQL_PASSWORD=<your_db_password>"
    networks:
      - back-wordpress

networks:
  front:
    external: true
  back-wordpress:
    external: true
map $http_upgrade $connection_upgrade {
  default upgrade;
  ''      close;
}

server {
  listen 20092; # docker-compose.ymlの方と合わせておく
  server_name <your_domain>;

  ssl_protocols TLSv1.2;
  ssl_ciphers EECDH+AESGCM:EECDH+AES;
  ssl_ecdh_curve prime256v1;
  ssl_prefer_server_ciphers on;
  ssl_session_cache shared:SSL:10m;

  # 以下3行なしで一旦動作させて、letsencryptの鍵を取得後にnginxを再起動した方が、
  # 「鍵がないぞ!」と怒られてスタックするようなことがないのはバッドノウハウとして付け加えておく。
  ssl_certificate     /etc/nginx/certs/<your_domain>/fullchain.pem;
  ssl_certificate_key /etc/nginx/certs/<your_domain>/key.pem;
  ssl_dhparam         /etc/nginx/certs/dhparam.pem;

  keepalive_timeout    70;
  sendfile             on;
  client_max_body_size 0;

  gzip on;
  gzip_disable "msie6";
  gzip_vary on;
  gzip_proxied any;
  gzip_comp_level 6;
  gzip_buffers 16 8k;
  gzip_http_version 1.1;
  gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

  add_header Strict-Transport-Security "max-age=31536000";

  set_real_ip_from 10.10.0.0/16; # nginx-proxyのinternalなアドレス空間を指定。
  real_ip_header X-Forwarded-For;

  location / {
    try_files $uri @proxy;
  }

  location @proxy {
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto https;
    proxy_set_header Proxy "";
    proxy_pass_header Server;

    proxy_pass http://wordpress:80;
    proxy_buffering off;
    proxy_redirect off;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection $connection_upgrade;

    tcp_nodelay on;
  }
  error_page 500 501 502 503 504 /500.html;
}

创建桥梁并启动WordPress。

$ docker network create --driver bridge back-wordpress
$ cd ~/apps/wordpress
$ docker-compose up -d

一旦WordPress启动后,尝试在浏览器上访问并通过install.php进行安装,直到完成。

数据导入

进行wp-content的复制和展开,导入mysql的转储文件。

# wp-contentのコピー・展開
$ docker cp wp-content.tar.gz wordpress:/var/www/html
$ docker exec wordpress tar zxvf wp-content.tar.gz
$ docker exec wordpress /bin/bash -c "chown www-data:www-data -R /var/www/html/wp-content"
# wp-contentのパーミッション変更 (cacheはないことも)
$ docker exec wordpress /bin/bash -c "chmod 777 -R /var/www/html/wp-content/cache && chmod 777 -R /var/www/html/wp-content/uploads"

# mysqlのダンプファイルインポート
$ docker cp wordpress_mysql.sql mysql:/tmp/
// インポート
# docker exec mysql /bin/bash -c "mysql --default-character-set=utf8 -h mysql -u <your_db_user> -p<your_db_password> <your_db_name> < /tmp/wordpress_mysql.sql"

任务已完成!

广告
将在 10 秒后关闭
bannerAds