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

fcg9iug3  于 2023-04-29  发布在  Docker
关注(0)|答案(2)|浏览(138)

我正在尝试使用Laravel Sail在本地运行一个现有的项目。1049未知数据库错误我尝试了以下方法:

sail php artisan config:clear
sail php artisan config:cache

我还尝试用www. example代替mysql作为主机 www.example.com .示例文件,但没有运气。
我也试着重建容器,但似乎没有解决问题。

这是我的。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和数据库。php配置文件都是一样的。新的安装启动良好,我可以连接到数据库,现有的项目仍然不工作。真的很困惑.

shyt4zoc

shyt4zoc1#

好的,经过大量的挖掘,我终于能够让这个工作。我会为将来发生这种事的人解释我的发现。
我认为根本原因是我最初尝试在没有。env文件,它会导致为mysql创建一个卷,然后当你有一个.我找到了那个信息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文件,否则为它的。/vendor/bin/sail。..).
然后我做了一个sail down和一个sail up -d,然后是sail php artisan migrate,瞧,它成功了!

yh2wf1be

yh2wf1be2#

确保您使用正确的凭据创建了.env文件,然后:
sail down && sail up -d --force-recreate

相关问题