将 Wordpress 站点移至 Docker:建立数据库连接时出错

gob*_*ket 5 mysql wordpress docker docker-compose

我最近一直在用 Wordpress 和 Docker 创建新站点,并且对它的工作原理有一个合理的了解,我现在希望将一些已建立的站点移到 Docker 中。

我一直在遵循本指南:

https://stephenafamo.com/blog/moving-wordpress-docker-container/

我已经按原样设置了所有内容,但是当我转到我的 domain.com:1234 时,我收到错误消息“建立数据库连接时出错”。我已按照建议将 wp-config.php 中的“DB HOST”更改为“mysql”,并且我引入的站点中的所有 DB 详细信息都是正确的。

我已附加到 mysql 容器并检查数据库是否在那里并且使用了正确的用户,并且还通过 mysql CLI 确保 pw 也是正确的。

SELinux 设置为宽松,我没有更改任何目录/文件所有权或权限,对于后者,目录都是 755 和文件 644,因为它们应该是。

编辑:我应该提到数据库/数据及其下的所有内容似乎归用户/组“polkitd input”而不是 root 所有。

当我在端口 1234 上浏览站点时,除了 WP 容器的 500 错误消息之外,Docker 日志并没有真正告诉我很多信息(尽管如此)。

这是 docker-compose 文件:

version: '2'

services:
  example_db:
    image: mysql:latest
    container_name: example_db
    volumes:
      - ./database/data:/var/lib/mysql
      - ./database/initdb.d:/docker-entrypoint-initdb.d
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: password123 # any random string will do
      MYSQL_DATABASE: mydomin_db # the name of your mysql database
      MYSQL_USER: my domain_me # the name of the database user
      MYSQL_PASSWORD: password123 # the password of the mysql user

  example:
    depends_on:
      - example_db
    image: wordpress:php7.1 # we're using the image with php7.1
    container_name: example
    ports:
      - "1234:80"
    restart: always
    links:
      - example_db:mysql
    volumes:
      - ./src:/var/www/html
Run Code Online (Sandbox Code Playgroud)

建议最受欢迎,因为我没有想法!

xtr*_*tra 8

使用新版本的 docker-compose ,它将如下所示(如果您不想使用 PhpMyAdmin 您可以将其省略):

version: '3.7'

volumes:
  wp-data:
networks:
  wp-back:

services:

  db:
    image: mysql:5.7
    volumes:
      - wp-data:/var/lib/mysql
    environment:
       MYSQL_ROOT_PASSWORD: rootPassword
       MYSQL_DATABASE: wordpress
       MYSQL_USER: wp-user
       MYSQL_PASSWORD: wp-pass
    ports:
      - 8889:3306
    networks:
      - wp-back

  phpmyadmin:
    depends_on:
      - db
    image: phpmyadmin/phpmyadmin
    environment:
      PMA_HOST: db
      MYSQL_USER: wp-user
      MYSQL_PASSWORD: wp-pass
      MYSQL_ROOT_PASSWORD: rootPassword
    ports:
      - 3001:80
    networks:
      - wp-back

  wordpress:
    depends_on:
      - db
    image: wordpress:latest
    ports:
      - 8888:80
      - 443:443
    environment:
       WORDPRESS_DB_HOST: db
       WORDPRESS_DB_USER: wp-user
       WORDPRESS_DB_PASSWORD: wp-pass
    volumes:
      - ./wordpress-files:/var/www/html
    container_name: wordpress-site
    networks:
      - wp-back
Run Code Online (Sandbox Code Playgroud)

数据库卷是一个命名卷 wp-data,而 wordpress html 是绑定挂载到当前目录 ./wordpress-files 。


Coo*_*hal 1

请看一下下面的撰写脚本。我尝试过并测试过。效果很好。

version: '2'

services:
  db:
    image: mysql:latest
    container_name: db_server
    volumes:
      - ./database/data:/var/lib/mysql
      - ./database/initdb.d:/docker-entrypoint-initdb.d
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: password123 # any random string will do
      MYSQL_DATABASE: udb_test # the name of your mysql database
      MYSQL_USER: me_prname # the name of the database user
      MYSQL_PASSWORD: password123 # the password of the mysql user

  example:
    depends_on:
      - db
    image: wordpress:php7.1 # we're using the image with php7.1
    container_name: wp-web
    environment:
      WORDPRESS_DB_HOST: db:3306
      WORDPRESS_DB_USER: me_prname
      WORDPRESS_DB_PASSWORD: password123
      WORDPRESS_DB_NAME: udb_test
    ports:
      - "1234:80"
    restart: always
    volumes:
      - ./src:/var/www/html
Run Code Online (Sandbox Code Playgroud)

如果您遇到其他问题,请告诉我。