ホームページ >データベース >mysql チュートリアル >MySQL にリモートでアクセスできない問題を解決する方法を教えます
現在、多くのインターネット企業で mysql データベースの使用が止められない傾向になっているため、プロジェクトの開始時によく行うことは、Linux サーバーを見つけ、そこに mysql をインストールし、データ テーブルのインポート作業を開始することです。しかし、常にサーバーのリモート接続を占有できるわけではないので、データベースを操作するためにリモート ツールを使用することがよくありますが、次のような状況にも遭遇します:
MYSQL CONNECT ERROR – 1130:Host ’202.43.**.**’ is not allowed to connect to this MySQL server“
上記のような状況が表示されます。 接続が拒否される根本的な理由は、リモート ツールであることです。 mysql アカウントの作成時には、接続アカウントのログインが制限されます。つまり、mysql が配置されている現在のインストール サーバーを除き、ユーザー名とパスワードが正しい場合でも、他の IP (ホスト) からのアクセスは許可されません。 ; 実際、MySQL がデフォルトでリモート コントロールをサポートしていないのではなく、MySQL のデフォルト ユーザー root がデフォルトでリモート コントロールをサポートしていないのは、root ユーザーのホストが 127.0.0.1 であるということです。最も簡単な方法は、root 権限を変更せずにリモート アクセスをサポートするユーザーを再起動することです。ただし、本当に root リモート操作を使用する必要がある場合は、この方法はありません。それを解決する2つの解決策:
① etc/mysql/my.cnfの[mysqld]セクションのbind-address = 127.0.0.1をコメントアウトします
②mysql -uroot -pを使用してmysqlにログインし、次のメソッドを使用してリモート アクセスを有効にします。
#mysql -u root -p #*******(密码,默认的密码是空) mysql>use mysql; mysql>update user set host = '%' where user = 'root'; mysql>flush privileges;
コードを実行すると、root ユーザーに対応するホストが % であることがわかります。これは、以下に示すように、すべての IP 接続が許可されていることを意味します。
上記の説明プロセスにより、一部の mysql ユーザーにとって、mysql のデフォルトのパスワードが空であってもあまり気にしないことがわかりました。そこで、mysql をインストールしたばかりの皆さんに、インストールが完了した後に注意してください。 、空のユーザーをクリアし、時間内にパスワードを変更することを忘れないでください。次のように、これら 2 つのプロセスを簡単に記録してみましょう:
出典 : MySQL データベースのリリース バージョンに関する知識の説明mysql -u root -p mysql>select user,host,password from mysql.user; mysql>drop user ''@localhost; mysql>update mysql.user set password = PASSWORD('*********') where user='root'; mysql>flush privileges;実行プロセスは次のとおりです。
以上がMySQL にリモートでアクセスできない問題を解決する方法を教えますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。