問題:あるサーバー上の PHP プログラムは、localhost アドレス経由でデータベースに接続できませんが、127.0.0.1 に設定すると正常に接続でき、他のデータベース サーバーにも正常に接続できます。 MySQL の権限が正しく設定されており、mysql コマンドライン クライアントを介してデータベースに正常に接続できます。 分析:これはソケットが正しく構成されていない典型的なケースです。 MySQL データベースに接続するには、TCP/IP (一般にポートと呼ばれるもの) と Unix ソケット (一般にソケットまたはソックスと呼ばれるもの) の 2 つの方法があります。ほとんどの場合、localhost はローカルマシン 127.0.0.1 を表すために使用できますが、MySQL に接続する場合は 2 つを混在させることはできず、また、MySQL の権限設定でも localhost と 127.0.0.1 が別々に設定されます。 127.0.0.1 に設定すると、システムは TCP/IP 経由でデータベースに接続します。localhost に設定すると、システムはソケット経由でデータベースに接続します。 解決策: まず、ローカル MySQL のソケット ファイルがどこにあるかを確認します。確認するコマンドは次のとおりです。 mysqld --verbose --help | grep ソケット 出力にはソケットファイルの場所が表示されます。たとえば、このサーバーでは ソケット /var/run/mysqld/mysqld.sock 次に、それに対応するように PHP 設定ファイル php.ini を変更します。 これを見つけてください: mysql.default_socket = 通常、この項目は空なので、次のように変更します。 mysql.default_socket = /var/run/mysqld/mysqld.sock 前の手順で照会したファイルをここに書き込んで、状況に応じて設定する必要があります。この時点で、PHP の設定が変更されています。CLI (コマンドライン) モードまたは CGI モードの場合は、すぐに有効になります。FASTCGI モードの場合は、fastcgi プロセスを再起動する必要があります。 上記の記事は、MySQL が localhost 経由でデータベースに接続できない問題を完全に解決します。これは、編集者があなたと共有するすべてのコンテンツです。参考になれば幸いです。また、123WORDPRESS.COM をサポートしていただければ幸いです。 以下もご興味があるかもしれません:
|
<<: VMWare に CentOS 7.3 をインストールするグラフィカル チュートリアル
目次1. DIVとSPANの違いと特徴2. スパンタグの概要3. 拡大と改善4. 凡例の効果の実証例...
必要:バックグラウンド管理では、次のようなレイアウトでデータを表示する必要があることがよくあります。...
パフォーマンスの黄金律:エンドユーザーの応答時間のわずか 10% ~ 20% が HTML ドキュメ...
目次1. 上の写真2. ユーザーが存在しない3. コードをアップロードする1. 上の写真 2. ユー...
この記事では主に Vue プロジェクトを紹介します。要素の導入を前提として、コンポーネントを 2 回...
この記事では、Navicatを使用してcsvデータをmysqlにインポートする方法を参考までに紹介し...
Ubuntu 18のインストール中に、USBディスクからUbuntuのインストールを開始すると、mm...
これを実現するには、ES6 モジュール開発とオブザーバー モードを使用します。オブザーバー パターン...
昨日、1年間使用していた Alibaba Cloud サーバーを購入しました。システムは Linux...
目次需要背景Nginx を使用する理由は何ですか? Nginx によるポート転送依存関係をインストー...
NodeJS は次のファイルをコピーします:通常、小さなファイルのコピー操作では、ストリーム パイプ...
ファイルの切り替えは Linux でよく行われる操作です。Linux を初めて学ぶときに最初に触れる...
ステップ: 1. 仮想マシンディレクトリに新しいdocker-compose.ymlファイルを作成し...
前提条件: Web開発者プラグインがインストールされている操作手順: [ツール] -> [We...
この記事では、VMware 環境下で Ubuntu と Windows 間でファイルを共有する方法を...