ホームページ > データベース > mysql チュートリアル > 「localhost」を使用すると、「そのようなファイルまたはディレクトリはありません (unix:///tmp/mysql.sock 経由で接続しようとしています)」というメッセージが表示されて PDO 接続が失敗するのはなぜですか?

「localhost」を使用すると、「そのようなファイルまたはディレクトリはありません (unix:///tmp/mysql.sock 経由で接続しようとしています)」というメッセージが表示されて PDO 接続が失敗するのはなぜですか?

DDD
リリース: 2024-11-03 07:38:30
オリジナル
981 人が閲覧しました

Why Does My PDO Connection Fail With

PDO 接続エラー: 「そのようなファイルまたはディレクトリはありません (unix:///tmp/mysql.sock 経由で接続しようとしています)」

この質問では、ユーザーは、以前は機能していた PDO 経由でデータベースに接続する際の問題について懸念を表明しています。コードやデータベースに関連する設定を何も変更していないため、ユーザーは困惑しています。

ユーザーが提供した PHP コード スニペットは、TCP/IP 接続を確立しようとしていることを示唆しています。 「localhost」というホスト名を使用してデータベースに接続します。ただし、エラー メッセージは、代わりに Unix ソケット経由で接続しようとしていることを示しています。

解決策:

PHP が原因で、ユーザーは無意識のうちに Unix ソケットを使用しようとしています。クライアント ライブラリの「localhost」のデフォルトの処理。このライブラリは、「localhost」を TCP ホストではなくソケットの場所として解釈します。

このエラーを解決してローカル マシンへの TCP/IP 接続を確立するには、ユーザーはホスト名を「127.0.0.1」に置き換える必要があります。 PHP コード内:

<code class="php">new PDO('mysql:host=127.0.0.1;port=3306;dbname=test', 'username', 'password');</code>
ログイン後にコピー

Unix ソケットを使用する場合、ユーザーは「host」の代わりに「unix_socket」DSN オプションを使用して、DSN 内のその場所を明示的に指定できます。 localhost に使用される Unix ソケットの場所は、コンパイル時に構成できます。または、特定の PHP バージョンでは、php.ini ファイルの「pdo_mysql.default_socket」設定を変更することによって構成できます。

以上が「localhost」を使用すると、「そのようなファイルまたはディレクトリはありません (unix:///tmp/mysql.sock 経由で接続しようとしています)」というメッセージが表示されて PDO 接続が失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート