php - MySQL 连接访问被拒绝,但只有 50% 的时间,在带有 Nginx-Proxy 的 Docker 中

标签 php mysql docker nginx jwilder-nginx-proxy

我正在尝试让本地开发环境运行多个项目。 经过一番大修之后,我偶然发现了 this project ,并开始将其适应我自己的项目。 每个项目包含 2 个容器,一个 mysql 容器和一个 php 容器(来自 php-apache 图像)。

nginx-proxy 是一个在网络上运行的独立容器。我稍微重命名了这个项目,所以这里叫做 dev-router_default

我项目的 compose.yml 看起来像这样:

version: "3"
services:
  php:
    build: './.docker/php/'
    volumes:
      - .:/var/www/html/
    environment:
      - VIRTUAL_HOST=XXX.local
  mysql:
    build: './.docker/mysql/'
    ports:
      - "3309:3306"
    environment:
      MYSQL_DATABASE: XXX
      MYSQL_USER: XXX
      MYSQL_PASSWORD: XXX
      MYSQL_ROOT_PASSWORD: XXX
      VIRTUAL_HOST: XXX.local
networks:
  default:
    external:
      name: dev-router_default

这些文件夹中的 dockerfiles 现在只是基本图像。它们只是存在,所以我可以稍后扩大它们。

一切都很顺利。我可以访问数据库,我可以加载 html 和 php 页面。 然而。每当我加载页面时。我有 50% 的机会得到这个错误:

SQLSTATE[HY000] [1045] Access denied for user

其他 50% 的页面加载工作正常。 这不是密码错误或其他问题。设置都保持不变,但不知何故一个连接被拒绝而另一个连接通过。

我有一种直觉,nginx-proxy 有一半时间没有将我的流量重定向到正确的 mysql 容器。但我似乎无法找到调用发送到的位置。当我加载页面时,我在容器 CLI 中看到 php_1 加载的日志弹出窗口。但是 mysql_1 保持沉默。

有人知道造成这种不一致的原因吗?

有没有更简单的方法来设置同时使用多个虚拟主机/域的 docker 开发环境?

我需要能够访问多个数据库(我通过为每个项目提供一个特定的端口来实现此目的),并为绑定(bind)到 document_root 的每个项目提供唯一的 url。

最佳答案

这里的问题是服务的名称。 所有项目都有一个 php 和一个 mysql 容器。 我通过服务名称访问 mysql HOST(在本例中是所有项目的 mysql)。 主机“mysql”在多个项目中被多次定义。 命名 mysql 容器 projectname-mysql 修复它。

关于php - MySQL 连接访问被拒绝,但只有 50% 的时间,在带有 Nginx-Proxy 的 Docker 中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52547687/

相关文章:

mysql - 在特定日期更新数据库记录

sql - 为什么逗号弄乱了插入

django - docker 卡在点子安装

php - 如何防止 MySQL 使用空字符串更新列?

php - 使用php从两列mysql csv获取csv值

python - 如何授予 www-data 用户访问 python salt 模块的权限?

docker - Docker 有操作系统吗?

php - 使用循环将此数组转换为字符串的逻辑

php - 通过 PHP 的 MySql 源

docker - 上次使用的docker-compose命令