ホームページ > データベース > mysql チュートリアル > MySQL サーバーに接続できないのはなぜですか: 「ホスト 'xxx.xx.xxx.xxx' は許可されていません」

MySQL サーバーに接続できないのはなぜですか: 「ホスト 'xxx.xx.xxx.xxx' は許可されていません」

Linda Hamilton
リリース: 2024-12-16 16:47:17
オリジナル
728 人が閲覧しました

Why Can't I Connect to My MySQL Server:

MySQL サーバーに接続できません: 「ホスト 'xxx.xx.xxx.xxx' は許可されていません」

を確立しようとしていますMySQL サーバーにリモート接続すると、「ホスト 'xxx.xx.xxx.xxx' はこの MySQL サーバーへの接続を許可されていません。」というエラー メッセージが表示されます。ホスト値として「localhost」と「%」の両方を含むユーザー エントリがあるにもかかわらず、問題は解決しません。

説明

このエラーは通常、セキュリティ対策として発生します。データベースのセキュリティを確保するには、特定のホストへのアクセスを制限し、ワイルドカード (「%」または「_」) の使用を制限することをお勧めします。 「root」ユーザーのデフォルト権限には、Host='localhost' および User='' のエントリが含まれることが多く、これはより一般的な Host 値のエントリよりも優先されます。

Solution

この問題を解決するには、次の手順を検討してください。

  1. 新規作成管理者アカウント:

「localhost」または「%%」(すべてのホスト用) など、特定のホスト アクセス権を持つ新しい管理ユーザーを作成します。このユーザーに必要な権限を付与します。

mysql> CREATE USER 'monty'@'localhost' IDENTIFIED BY 'some_pass';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'monty'@'localhost'
    ->     WITH GRANT OPTION;
mysql> CREATE USER 'monty'@'%' IDENTIFIED BY 'some_pass';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'monty'@'%'
    ->     WITH GRANT OPTION;
ログイン後にコピー
  1. 特定のホストへのアクセスを制限する:

ユーザーを作成するときは、正確なホストを指定するか、接続を許可される IP アドレス。これにより、不正アクセスが確実に制限されます。

  1. ワイルドカード エントリの削除:

ワイルドカード ホスト ('%' または'_')、セキュリティを強化するために削除することをお勧めします。削除したら、FLUSH PRIVILEGES ステートメントを発行して付与テーブルを再ロードします。

これらの対策を実装することで、MySQL サーバーへの安全な接続を確立し、不正アクセスのリスクを軽減できます。

以上がMySQL サーバーに接続できないのはなぜですか: 「ホスト 'xxx.xx.xxx.xxx' は許可されていません」の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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