Laravel 在现有项目上航行 - 未知数据库 SQLSTATE[HY000] [1049]
Laravel Sail on Existing Project - Unknown Database SQLSTATE[HY000] [1049]
我正在尝试使用 Laravel Sail 在本地创建一个现有项目。我不断收到 1049 未知数据库错误。我试过以下方法:
sail php artisan config:clear
sail php artisan config:cache
我也试过用 127.1.1.0 代替 mysql 作为主机,就像 .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配置文件都是一样的。新安装启动正常,我可以连接到数据库,现有项目仍然无法正常工作。真糊涂..
好的,经过大量的挖掘,我终于能够让它工作了。我将向以后发生这种情况的任何人解释我发现的内容。
我认为根本原因是我最初在没有 .env 文件的情况下尝试 运行 sail up
命令,这导致为 mysql 创建一个卷,然后当您有 .env 文件时,不会重新创建。我找到了该信息 here,尽管提到的 --rmi 标志似乎对我没有任何作用。
所以我开始手动删除卷。我从 得到了他们的位置。我认为手动删除它们是错误的步骤,但这是它们所在的位置:
\wsl$\docker-desktop-data\version-pack-data\community\docker\volumes
手动删除它们会导致我下次构建时出现另一个错误,但我能够通过 运行 执行以下命令使用 here 找到的信息解决该问题:
docker volume prune
docker system prune
注意:我认为您可以 运行 这些而无需手动删除卷,并且可能会得到相同的结果。一般来说,我认为您不想从 Windows 资源管理器中手动删除 WSL 中的文件。
完成后,我 运行 以下内容清除缓存和配置:
sail php artisan cache:clear
sail php artisan config:clear
(假设您在 .bashrc 文件中设置了 sail 别名,否则为 ./vendor/bin/sail ...)。
然后我做了一个 sail down
和一个 sail up -d
然后 sail php artisan migrate
瞧,成功了!
我正在尝试使用 Laravel Sail 在本地创建一个现有项目。我不断收到 1049 未知数据库错误。我试过以下方法:
sail php artisan config:clear
sail php artisan config:cache
我也试过用 127.1.1.0 代替 mysql 作为主机,就像 .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配置文件都是一样的。新安装启动正常,我可以连接到数据库,现有项目仍然无法正常工作。真糊涂..
好的,经过大量的挖掘,我终于能够让它工作了。我将向以后发生这种情况的任何人解释我发现的内容。
我认为根本原因是我最初在没有 .env 文件的情况下尝试 运行 sail up
命令,这导致为 mysql 创建一个卷,然后当您有 .env 文件时,不会重新创建。我找到了该信息 here,尽管提到的 --rmi 标志似乎对我没有任何作用。
所以我开始手动删除卷。我从
\wsl$\docker-desktop-data\version-pack-data\community\docker\volumes
手动删除它们会导致我下次构建时出现另一个错误,但我能够通过 运行 执行以下命令使用 here 找到的信息解决该问题:
docker volume prune
docker system prune
注意:我认为您可以 运行 这些而无需手动删除卷,并且可能会得到相同的结果。一般来说,我认为您不想从 Windows 资源管理器中手动删除 WSL 中的文件。
完成后,我 运行 以下内容清除缓存和配置:
sail php artisan cache:clear
sail php artisan config:clear
(假设您在 .bashrc 文件中设置了 sail 别名,否则为 ./vendor/bin/sail ...)。
然后我做了一个 sail down
和一个 sail up -d
然后 sail php artisan migrate
瞧,成功了!