P粉7319775542023-08-11 00:43:41
このエラーの最も単純な原因の 1 つは、MySQL サーバーが実行されていないことです。したがって、最初のステップは検証することです。機能している場合は、他の提案を続けてください:
まったく同じ問題に遭遇しました。上記の解決策はどれも私にとっては役に立ちませんでした。 /app/config/database.php ファイルの「host」を「localhost」から「127.0.0.1」に変更することで問題を解決しました。
「localhost」がデフォルトで機能しない理由はわかりませんが、symfony2 の投稿で解決された同様の問題に対するこの回答を見つけました。 https://stackoverflow.com/a/9251924
更新: なぜこの修正が機能するのかという質問があったので、この問題について調べてみました。この投稿で説明したように、それらは異なる接続タイプを使用します。 https://stackoverflow.com/a/9715164
ここでの問題は、「localhost」が UNIX ソケットを使用しているため、標準ディレクトリでデータベースが見つからないことです。ただし、「127.0.0.1」は TCP (伝送制御プロトコル) を使用します。つまり、コンピュータ上の「ローカル ネットワーク」上で実行され、UNIX ソケットよりも信頼性が高くなります。
P粉1484347422023-08-11 00:10:06
エラー メッセージは、ソケット (サポートされていない) を介して MySQL 接続を確立しようとしていることを示しています。
Laravel (artisan) のコンテキストでは、別の/正しい環境を使用したい場合があります。例: php 職人 移行 --env=production
(またはその他の環境)。 ここを参照してください。