【发布时间】:2021-04-10 08:03:33
【问题描述】:
根据文档:
另外,当 MySQL 容器启动时,它会确保存在一个名称与您的 DB_DATABASE 环境变量的值匹配的数据库。
我的.env 文件如下所示。
DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=test
DB_USERNAME=root
DB_PASSWORD=
然而,当我尝试通过 sail artisan migrate 运行迁移时,我得到了这个错误:
SQLSTATE[HY000] [1049] Unknown database 'test' (SQL: select * from information_schema.tables where table_schema = test and table_name = migrations and table_type = 'BASE TABLE')
我尝试过的:
- 同时删除 docker 容器和图像。
- 运行
sail build --no-cache(尝试完全重建所有内容) - 在运行
sail shell时,我进入 MySQL 并显示所有数据库。我可以在那里看到默认的 laravel 数据库。
你如何告诉sail创建正确的DB_DATABASE?
我的docker-compose.yml:
# For more information: https://laravel.com/docs/sail
version: '3'
services:
laravel.test:
build:
context: ./vendor/laravel/sail/runtimes/8.0
dockerfile: Dockerfile
args:
WWWGROUP: '${WWWGROUP}'
image: sail-8.0/app
ports:
- '${APP_PORT:-80}:80'
environment:
WWWUSER: '${WWWUSER}'
LARAVEL_SAIL: 1
volumes:
- '.:/var/www/html'
networks:
- sail
depends_on:
- mysql
- redis
mysql:
image: 'mysql:8.0'
ports:
- '${FORWARD_DB_PORT:-3306}:3306'
environment:
MYSQL_ROOT_PASSWORD: '${DB_PASSWORD}'
MYSQL_DATABASE: '${DB_DATABASE}'
MYSQL_USER: '${DB_USERNAME}'
MYSQL_PASSWORD: '${DB_PASSWORD}'
MYSQL_ALLOW_EMPTY_PASSWORD: 'yes'
volumes:
- 'sailmysql:/var/lib/mysql'
networks:
- sail
redis:
image: 'redis:alpine'
ports:
- '${FORWARD_REDIS_PORT:-6379}:6379'
volumes:
- 'sailredis:/data'
networks:
- sail
mailhog:
image: 'mailhog/mailhog:latest'
ports:
- 1025:1025
- 8025:8025
networks:
- sail
networks:
sail:
driver: bridge
volumes:
sailmysql:
driver: local
sailredis:
driver: local
【问题讨论】:
-
确保你运行的是
sail artisan migrate而不是php artisan migrate -
你在运行什么镜像?它是官方的还是你有一个 Dockerfile?你是如何启动容器的?
-
官方的,我没有做任何定制。运行它:
sail up. -
@Ezrab_ 你能添加你的
docker-compose.yml的内容吗?它应该位于项目的根目录中。
标签: mysql laravel docker laravel-sail