MySQL 连接访问被拒绝,但只有 50% 的时间,Docker 使用 Nginx-Proxy

MySQL Connection access denied, but only 50% of the time, in Docker with 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 的开发环境,同时使用多个虚拟 hosts/domains?

我需要能够访问多个数据库(我通过给每个项目一个特定的端口来实现这一点),并且每个项目都有一个唯一的 url [=20] =].

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