gpt4 book ai didi

docker - Laravel 5 应用程序无法在 docker 容器中连接 MariaDB 引擎

转载 作者:行者123 更新时间:2023-12-02 18:17:14 25 4
gpt4 key购买 nike

我在 docker 容器中创建了一个新的 Laravel 5 应用程序。我可以访问主页 url 并收到欢迎消息。我尝试创建新路线,它们也在工作。然后我运行一个 MariaDB docker 容器来链接到 Laravel 5 应用程序。这是问题开始的地方。
当我尝试使用以下命令在 Laravel 5 中运行迁移时:

php artisan migrate --force

我收到以下错误消息:
Can't connect to MySQL server on '127.0.0.1'

我的 .env 文件是这样的:
    DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_DATABASE=blog
DB_USERNAME=blog
DB_PASSWORD=123456

我知道 Laravel 使用这些变量来连接数据库,因为它们存在于 Laravel 日志文件中,如下所示:
PDO->__construct(‘mysql:127….’, ‘blog’,  ‘123456’, Array)

数据库引擎是 MariaDB,它在 docker 容器中运行。这个 docker 容器暴露了 3306 端口并链接到运行 Laravel 的容器。要链接容器,我使用以下 docker 命令:
docker run –i –t - - link mariadb:mysql miguelbgouveia/laravel:v3 /bin/bash 

我也知道我的 MariaDB docker 容器正在以正确的配置运行,因为我使用了一个链接到它的 phpmyadmin docker 容器,并且我可以成功连接到数据库。我将 MariaDB 容器与 phpmyadmin 容器链接起来,方式与将它链接到 Laravel 容器的方式相同(--link mariadb:mysql)

为什么我无法连接到数据库?是否缺少要安装的任何配置或 php 模块?

最佳答案

毕竟很简单。如果我在环境变量中使用 mysql 主机,它就可以工作,而无需知道 MariaDB docker 容器的 IP 地址。
.env 文件如下所示:

DB_CONNECTION=mysql
DB_HOST=mysql
DB_DATABASE=blog
DB_USERNAME=blog
DB_PASSWORD=123456

现在我可以成功连接 MariaDB 引擎了。

关于docker - Laravel 5 应用程序无法在 docker 容器中连接 MariaDB 引擎,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30462384/

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