gpt4 book ai didi

php - 使用 laradock 迁移 Laravel 数据库失败

转载 作者:行者123 更新时间:2023-12-02 19:34:46 24 4
gpt4 key购买 nike

我收到以下错误

[Illuminate\Database\QueryException]                                                                                                                 
SQLSTATE[HY000] [2002] Connection refused (SQL: select * from information_schema.tables where table_schema = testdb and table_name = migrations)

当我运行时-
php artisan migrate

我在 laradock 工作区上运行这个命令。我使用以下命令进入工作区。
docker-compose exec workspace bash

我正在使用 laravel 5.5。我以下列方式在我的项目文件夹中有 laradock。
 +testproject
-Laradock

我的项目 .env (testproject/.env) 文件包含以下 mysql 设置。
DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=33060
DB_DATABASE=testdb
DB_USERNAME=root
DB_PASSWORD=root

我的 laradock .env(testproject/laradock/.env) 文件包含以下 mysql 设置。
MYSQL_VERSION=8.0
MYSQL_DATABASE=testdb
MYSQL_USER=default
MYSQL_PASSWORD=secret
MYSQL_PORT=33060
MYSQL_ROOT_PASSWORD=root
MYSQL_ENTRYPOINT_INITDB=./mysql/docker-entrypoint-initdb.d

我的 docker-compose.yml 包含 Mysql Container 的以下设置
mysql:
build:
context: ./mysql
args:
- MYSQL_VERSION=${MYSQL_VERSION}
environment:
- MYSQL_DATABASE={MYSQL_DATABASE}
- MYSQL_USER={MYSQL_USER}
- MYSQL_PASSWORD={MYSQL_PASSWORD}
- MYSQL_ROOT_PASSWORD={MYSQL_ROOT_PASSWORD}
- TZ=${WORKSPACE_TIMEZONE}
volumes:
- ${DATA_SAVE_PATH}/mysql:/var/lib/mysql
- ${MYSQL_ENTRYPOINT_INITDB}:/docker-entrypoint-initdb.d
ports:
- "${MYSQL_PORT}:3306"
networks:
- backend

docker中的mysql安装在33060端口。我是第一次尝试laradock。在尝试了几种配置之后,我现在正在呼唤复仇者联盟!

最佳答案

通过具有以下mysql设置解决了该问题。

测试项目/.env:

DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=testdb
DB_USERNAME=root
DB_PASSWORD=root

测试项目/laradock/.env:
MYSQL_VERSION=8.0
MYSQL_DATABASE=default
MYSQL_USER=default
MYSQL_PASSWORD=secret
MYSQL_PORT=33060
MYSQL_ROOT_PASSWORD=root
MYSQL_ENTRYPOINT_INITDB=./mysql/docker-entrypoint-initdb.d

testproject/laradock/docker-compose.yml
mysql:
build:
context: ./mysql
args:
- MYSQL_VERSION=${MYSQL_VERSION}
environment:
- MYSQL_DATABASE=${MYSQL_DATABASE}
- MYSQL_USER=${MYSQL_USER}
- MYSQL_PASSWORD=${MYSQL_PASSWORD}
- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}
- TZ=${WORKSPACE_TIMEZONE}
volumes:
- ${DATA_SAVE_PATH}/mysql:/var/lib/mysql
- ${MYSQL_ENTRYPOINT_INITDB}:/docker-entrypoint-initdb.d
ports:
- "${MYSQL_PORT}:3306"
networks:
- backend

我还在 laradock 文件夹中运行了以下两个命令
docker-compose down

docker-compose up -d mysql

关于php - 使用 laradock 迁移 Laravel 数据库失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46931196/

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