mysql连接访问被拒绝,但只有50%的时间,在docker与nginx代理

axkjgtzd  于 2021-06-19  发布在  Mysql
关注(0)|答案(1)|浏览(448)

我正在尝试让一个本地开发环境运行多个项目。经过一番繁重的修修补补,我偶然发现了这个项目,并开始把它改编成我自己的项目。每个项目由2个容器组成,一个mysql容器和一个php容器(来自 php-apache 图像)。
这个 nginx-proxy 是在网络上运行的独立容器。我稍微重新命名了这个项目,所以这里叫做 dev-router_default .
我的项目 compose.yml 看起来像这样:

  1. version: "3"
  2. services:
  3. php:
  4. build: './.docker/php/'
  5. volumes:
  6. - .:/var/www/html/
  7. environment:
  8. - VIRTUAL_HOST=XXX.local
  9. mysql:
  10. build: './.docker/mysql/'
  11. ports:
  12. - "3309:3306"
  13. environment:
  14. MYSQL_DATABASE: XXX
  15. MYSQL_USER: XXX
  16. MYSQL_PASSWORD: XXX
  17. MYSQL_ROOT_PASSWORD: XXX
  18. VIRTUAL_HOST: XXX.local
  19. networks:
  20. default:
  21. external:
  22. name: dev-router_default

这个 dockerfiles 在这些文件夹中,现在只是基本的图像。它们的存在只是为了我以后可以放大它们。
一切都很顺利。我可以访问数据库,我可以加载html和php页面。然而。每当我加载页面时。我有50%的机会得到这个错误:

  1. SQLSTATE[HY000] [1045] Access denied for user

另外50%的页面负载工作正常。这不是一个错误的密码问题或任何东西。所有设置都保持不变,但不知何故一个连接被拒绝,另一个通过。
我有种直觉 nginx-proxy 有一半时间没有将我的流量重定向到正确的mysql容器。但我好像找不到电话的目的地。当我加载一个页面时,我在我的容器cli中看到了php\u1加载的日志弹出窗口。但是你保持沉默。
有人知道是什么导致这种不一致吗?
有没有一种更简单的方法可以用docker建立一个同时使用多个虚拟主机/域的开发环境?
我需要能够访问多个数据库(我这样做是给每个项目一个特定的端口来通过现在),并有一个唯一的url为每个项目绑定到一个数据库 document_root .

lqfhib0f

lqfhib0f1#

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

相关问题