Laravel 在现有项目上航行 - 未知数据库 SQLSTATE[HY000] [1049]

Posted

技术标签:

【中文标题】Laravel 在现有项目上航行 - 未知数据库 SQLSTATE[HY000] [1049]【英文标题】:Laravel Sail on Existing Project - Unknown Database SQLSTATE[HY000] [1049] 【发布时间】: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 部分。 【参考方案1】:

好的,经过大量的挖掘,我终于能够让它工作了。我将为将来发生这种情况的任何人解释我的发现。

我认为根本原因是我最初尝试在没有 .env 文件的情况下运行 sail up 命令,这会导致为 mysql 创建一个卷,然后当你有一个 .env 时不会重新创建文件。我发现了 here 的信息,尽管提到的 --rmi 标志似乎对我没有任何作用。

所以我从手动删除卷开始。我从this SO answer 获得了他们的位置。我认为手动删除它们是错误的步骤,但这里是它们的位置:

\\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 文件中设置了sai 别名,否则为 ./vendor/bin/sail ...)。

然后我做了一个sail down 和一个sail up -d,然后是sail php artisan migrate,瞧,它成功了!

【讨论】:

以上是关于Laravel 在现有项目上航行 - 未知数据库 SQLSTATE[HY000] [1049]的主要内容,如果未能解决你的问题,请参考以下文章

现有项目的 Laravel 火花?

Laravel迁移在现有数据库表中添加列问题

使用现有表模式上的数据透视表在雄辩模型中指定关系字段

来自现有表和项目的 laravel 身份验证

Laravel 转换现有用户系统多类型

如何将数组推送到 laravel 中的现有会话