ホームページ >データベース >mysql チュートリアル >Localhost からデータベースに接続すると「アクセス許可が拒否されました」エラーが発生するのはなぜですか?

Localhost からデータベースに接続すると「アクセス許可が拒否されました」エラーが発生するのはなぜですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-11-01 13:02:02824ブラウズ

Why Am I Getting a

データベースへの接続に関するトラブル: エラー コード 2002 (権限が拒否されました)

データベースに接続しようとしたときに、PHP スクリプトで次のエラーが発生しました。エラー「データベース接続エラー タイプ: 2002: アクセス許可が拒否されました。」この問題は、ローカルホストからスクリプトを実行するときに発生しましたが、コマンド ラインからは発生しませんでした。

調査の結果、エラーは SELinux セキュリティ ポリシーに起因することが判明しました。デフォルトでは、ポリシー「httpd_can_network_connect_db」は無効になっており、Web サーバーがリモート データベースとの接続を確立できません。

問題を解決するには:

  1. コマンドを使用してポリシーのステータスを確認します。 :
getsebool -a | grep httpd
  1. 「httpd_can_network_connect_db」が「オフ」に設定されている場合は、永続的に有効にします:
setsebool -P httpd_can_network_connect_db 1

これらを作成した後、Web サーバーを再起動します変更により、ローカルホストからのデータベース接続が成功するようになります。

以上がLocalhost からデータベースに接続すると「アクセス許可が拒否されました」エラーが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。