【发布时间】:2021-08-10 15:38:56
【问题描述】:
我正在尝试使用 Laravel Sail 在本地处理现有项目。我不断收到 1049 未知数据库错误。我尝试了以下方法:
sail php artisan config:clear
sail php artisan config:cache
我也尝试将 mysql 作为主机替换为使用 127.1.1.0 像 .env.example 文件,但没有运气。
我也尝试过重建容器,但似乎无法解决问题。
这是我的 .env 文件(当我尝试使用非 root 用户时,我收到 1045 错误,提示访问被拒绝,想知道这些是否相关):
DB_CONNECTION=mysql
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=root
DB_PASSWORD=
这是我的 docker-compose.yml 文件:
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
数据库配置:
'mysql' => [
'driver' => 'mysql',
'url' => env('DATABASE_URL'),
'host' => env('DB_HOST', '127.0.0.1'),
'port' => env('DB_PORT', '3306'),
'database' => env('DB_DATABASE', 'forge'),
'username' => env('DB_USERNAME', 'forge'),
'password' => env('DB_PASSWORD', ''),
'unix_socket' => env('DB_SOCKET', ''),
'charset' => 'utf8mb4',
'collation' => 'utf8mb4_unicode_ci',
'prefix' => '',
'prefix_indexes' => true,
'strict' => false,
'engine' => null,
'options' => extension_loaded('pdo_mysql') ? array_filter([
PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
]) : [],
],
更新:
我在同一个 WSL 安装的相邻目录中安装了全新安装的 laravel,并验证了 docker-compose.yml、.env 和 database.php 配置文件都相同。新安装启动正常,我可以连接到数据库,现有项目仍然无法正常工作。真的很迷茫。。
【问题讨论】:
-
你的数据库中真的有
laravel数据库吗? -
您的问题中的 docker-compose.yml 文件是否完整?如果您的 PHP 应用程序未在 Docker 容器中运行,则它无法与您的 MySQL 通信,因为 MySQL 不公开任何端口。如果是这样,我会发布一个详细的答案。
-
laravel 数据库不存在,但根据 Laravel Sail 文档,它应该确保在您启动容器时数据库存在。
-
docker-compose.yml 文件在我的问题中并不完整,我只是取出了我认为相关的 mysql 部分。
标签: php docker laravel-8 mysql-8.0 laravel-sail