it-swarm-ja.com

phpMyAdminを使用してリモートデータベースに接続できますか?

最近 このチュートリアルを読んでください これは、phpMyAdminのローカルインストールを簡単に再構成してリモートデータベースに接続する方法を説明しています。この機能はサポートされているようですが、デフォルトでは有効になっていません。チュートリアルに従いましたが、リモートホストに接続しようとすると、検証が失敗します。

誰かが関連する質問へのコメントで、MySQLログインは[email protected]の形式をとると説明しました。リモートデータベースは[email protected]を予期しますが、phpMyAdminは[email protected]を送信します。

彼がそれについて正しければ、それは私の問題かもしれません。記事がそれについて言及していないので、これはしかし混乱を招きます。


  1. PhpMyAdminを使用してリモートサーバー(Amazon EC2でホストされている)に実際に接続できますか?

  2. これは私の接続の試みにおける本当の問題でしょうか?

  3. もしそうなら、どうすればそれを解決できますか?

4
user317572

phpMyAdminは、リモートマシンのホスト、ユーザー、パスワードを設定するだけで、リモートデータベースに接続できます。ホストでMySQLポートが開いている限り、そこで実行されているMySQLはネットワーク接続を許可するように構成されており、ユーザーにはリモート接続の権限があります。

PhpMyAdminを実行しているマシンまたは他のマシン(MySQLサーバーではない)から、コマンドラインクライアントを実行して、接続が可能かどうかをテストします。

$ mysql -h<ip> -u<user> -p<password> <database>

IpはMySQLサーバーのIPであり、databaseはデータベースの名前であり、userとpasswordはMySQLのユーザーの資格情報です。これにより、mysqlクライアントが成功したときにプロンプ​​トが表示されます。またはエラーの適切な説明。

[〜#〜] update [〜#〜]

MySQLサーバーは通常、ローカルソケットのみをリッスンするように構成されています。 ti 3306 TCPデフォルトではポートをバインドしません。正しく構成するには、サーバーの構成ファイル(通常は/etc/my.cnf)を編集する必要があります)

[mysqld]
bind-address            = 10.0.0.5

この例のIPをサーバーのIPアドレスに置き換える必要があります。また、オプション「skip-networking」がアクティブになっていないことを確認する必要があります。これは、MySQLが構成されたIPをバインドできなくなるためです。

再起動後、MySQLがサーバーのシェルで次のコマンドをリッスンしているかどうかを確認できます。

# netstat -nap | grep mysqld
tcp        0      0 10.0.0.5:3306                0.0.0.0:*                   LISTEN      3547/mysqld
unix  2      [ ACC ]     STREAM     LISTENING     13554  3547/mysqld         /var/lib/mysql/mysql.sock

ここで最初の出力のような行を確認する必要があります。 3306番号はデフォルトのMySQLポートであり、サーバーを保護するファイアウォールがある場合は、着信TCP接続用に開く必要があります。

この後、MySQLに接続できるようになります。ただし、権限が適切に設定されていないと、ログインに問題が発生する可能性があります。 MySQLユーザーのユーザー名とホストはuser @ Hostの形式であるため、ユーザーを作成した場合my_user @ localhost localhostとは異なる場所からログインしようとすると、アクセスが拒否されます。クライアントがIPアドレス10.0.0.33のマシン上で実行されており、データベースへのアクセスを許可したいとします。ユーザーは[email protected]またはmy_user @%である必要があります。これは、任意のマシンから接続するための2番目の無制限ユーザーです。クライアントのIPを事前に知っている場合は、どちらを避けるのがよいでしょう。

1
drk.com.ar

Mysqlユーザーがリモートマシンからログインできるようにする必要があります。そのためには、mysqlサーバーで次のコマンドを実行する必要があります。* GRANT ALL PRIVILEGES ON TO'USERNAME '@'% 'IDENTIFIED BY'PASSWORD' *

さらに、構成ファイルを編集してmysqlサーバーのIPバインディングを無効にする必要があります

0
JPS Bhullar