Laravel Sail を使用して、既存のプロジェクトをローカルでスプールしようとしています。1049 不明なデータベース エラーが頻繁に発生します。私は次のことを試しました:
sail php artisan config:clear
sail php artisan config:cache
また、ホストとして mysql を .env.example ファイルのように 127.1.1.0 を使用するように置き換えてみましたが、うまくいきませんでした。
コンテナの再構築も試みましたが、問題は解決していないようです。
これが私の .env ファイルです (ルート以外のユーザーで試してみると、アクセスが拒否されたことを示す 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構成ファイルがすべて同じであることを確認しました。新しいインストールは正常に起動し、DB に接続できますが、既存のプロジェクトはまだ機能しません。本当に混乱..