ホームページ  >  に質問  >  本文

PDOException SQLSTATE ファイルまたはディレクトリが存在しません

<p> (非常に基本的な) Web サイトを fortrabbit に正常にデプロイできたと思いますが、SSH に接続したら、<code>php 職人移行</code> または <code>php 職人 db:seed< などのコマンドを実行します。 ;/code>)、次のエラー メッセージが表示されます: </p> <pre class="brush:php;toolbar:false;">[PDOException] SQLSTATE[HY000] [2002] そのようなファイルまたはディレクトリはありません <p>テーブルが存在するため、ある時点で移行は成功したはずですが、それはなぜ今うまくいかないのかの説明にはなりません。 </p>
P粉038161873P粉038161873435日前589

全員に返信(2)返信します

  • P粉731977554

    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 ソケットよりも信頼性が高くなります。

    返事
    0
  • P粉148434742

    P粉1484347422023-08-11 00:10:06

    エラー メッセージは、ソケット (サポートされていない) を介して MySQL 接続を確立しようとしていることを示しています。

    Laravel (artisan) のコンテキストでは、別の/正しい環境を使用したい場合があります。例: php 職人 移行 --env=production (またはその他の環境)。 ここを参照してください。

    返事
    0
  • キャンセル返事