我正在尝试使用 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 配置文件都相同。新安装启动正常,我可以连接到数据库,现有项目仍然无法正常工作。真的很迷茫。。
好的,经过大量的挖掘,我终于能够让它工作了。我将为将来发生这种情况的任何人解释我的发现。
我认为根本原因是我sail up最初尝试在没有 .env 文件的情况下运行该命令,这会导致为 mysql 创建一个卷,然后当你有一个 .env 文件时不会重新创建。我在这里找到了这些信息,尽管提到的 –rmi 标志似乎对我没有任何作用。
sail up
所以我从手动删除卷开始。我从这个 SO answer得到了他们的位置。我认为手动删除它们是错误的步骤,但这里是它们的位置:
\\wsl$\docker-desktop-data\version-pack-data\community\docker\volumes
下次构建时手动删除它们会导致另一个错误,但我能够通过运行以下命令使用此处找到的信息解决该问题:
docker volume prune docker system prune
注意:我认为您可以在不手动删除卷的情况下运行这些,并且可能具有相同的结果。通常,我认为您不想从 Windows 资源管理器中手动删除 WSL 中的文件。
完成后,我运行以下命令来清除缓存和配置:
sail php artisan cache:clear sail php artisan config:clear
(这些假设您在 .bashrc 文件中设置了sai 别名,否则为 ./vendor/bin/sail …)。
然后我做了一个sail down和一个sail up -d,然后sail php artisan migrate瞧,它奏效了!
sail down
sail up -d
sail php artisan migrate