gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 21:39:12 27 4
gpt4 key购买 nike

我正在尝试让本地开发环境运行多个项目。经过一番大修之后,我偶然发现了 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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com