mysql - 如何从 wordpress docker 建立数据库连接

标签 mysql wordpress docker docker-compose

我尝试使用本指南运行 docker compose wordpress:https://docs.docker.com/compose/wordpress/

这是指南中描述的 yaml 文件:

version: '3.3'
services:
   db:
     image: mysql:5.7
     volumes:
       - db_data:/var/lib/mysql
     restart: always
     environment:
       MYSQL_ROOT_PASSWORD: wordpress
       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
       WORDPRESS_DB_NAME: wordpress
       WORDPRESS_DEBUG: "true"
volumes:
    db_data: {}

在我运行我的之后

"docker-compose up -d" 

命令,我在浏览器中转到“http://localhost:8000/”,并获得显示“建立数据库连接时出错”的白页。根据指南,此时 wordpress 应该已经向我展示了 5 分钟的安装过程。当我使用 wordpress debug true 运行容器时,会显示此错误消息:

Warning: mysqli_real_connect(): (HY000/2002): Connection refused in /var/www/html/wp-includes/wp-db.php on line 1612

连接被拒绝

我现在用

docker exec it container_id /bin/bash 

然后键入“mysql -p”。现在我使用 docker compose 文件中的 MYSQL_ROOT_PASSWORD 但访问被拒绝(“用户 'root'@'localhost' 的访问被拒绝(使用密码:是)”)

我不确定我之前做了什么,但在某些时候它起作用了,我列出了数据库和 mysql.users 以及数据库和用户。

所以我什至不知道,这里的问题是什么......

为什么我不能再以 root 身份访问?有谁知道该怎么做吗?

编辑:将端口改回 3306,我尝试了 3308 只是想看看这是否可能是端口问题

最佳答案

我找到了另一个帖子,他们使用了这个 yaml。仍然不确定为什么会这样,但确实如此。

version: '3.3'
services:
   db:
     image: mysql:5.7
     volumes:
       - db_data:/var/lib/mysql
     restart: always
     environment:
       MYSQL_ROOT_PASSWORD: wordpress
       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:
    db_data: {}

关于mysql - 如何从 wordpress docker 建立数据库连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55418899/

相关文章:

php - MySQL一对多按连接表中的数字排序

php - 如何在 PHP PDO 中创建函数插入

php - MySQL - 查询创建的记录 "today",但日期为 UTC

php - 虽然循环无法正常工作

php - 如何在 PHP 中声明一个可以跨模板使用的全局变量?

docker - 使用docker-compose创建和挂载仅数据容器

php - 我的 sql 查询中的数据未显示

wordpress - 为什么WPML的 "String translation"中没有出现字符串?

ruby-on-rails - 配置 docker 卷以跨主机和容器共享数据

来自同一镜像的 Docker 容器无法按预期工作