2016-04-13 18 views
1

リモートRHELマシンにXAMPPをインストールしました。このマシンのIPアドレスが10.120.42.70であるとします。リモートアクセスのためにファイル/opt/lampp/etc/my.cnfを設定し、このファイルを/etc/my.cnfに移動して、このファイルの設定がmysqlサーバのグローバルオプションになるようにしました。ローカルのWindowsからRHELのリモートMySQLサーバに接続できません

は、ここに私の/etc/my.cnfファイル

# Example MySQL config file for medium systems. 
# 
# This is for a system with little memory (32M - 64M) where MySQL plays 
# an important part, or systems up to 128M where MySQL is used together with 
# other programs (such as a web server) 
# 
# You can copy this file to 
# /etc/my.cnf to set global options, 
# mysql-data-dir/my.cnf to set server-specific options (in this 
# installation this directory is /opt/lampp/var/mysql) or 
# ~/.my.cnf to set user-specific options. 
# 
# In this file, you can use all long options that a program supports. 
# If you want to know which options a program supports, run the program 
# with the "--help" option. 

# The following options will be passed to all MySQL clients 
[client] 
#password = your_password 
port  = 3306 
socket  = /opt/lampp/var/mysql/mysql.sock 

# Here follows entries for some specific programs 

# The MySQL server 
[mysqld] 
user = mysql 
port=3306 
socket  = /opt/lampp/var/mysql/mysql.sock 
#skip-external-locking 
key_buffer = 16M 
max_allowed_packet = 1M 
table_open_cache = 64 
sort_buffer_size = 512K 
net_buffer_length = 8K 
read_buffer_size = 256K 
read_rnd_buffer_size = 512K 
myisam_sort_buffer_size = 8M 
bind-address = 0.0.0.0 


# Where do all the plugins live 
plugin_dir = /opt/lampp/lib/mysql/plugin/ 

# Don't listen on a TCP/IP port at all. This can be a security enhancement, 
# if all processes that need to connect to mysqld run on the same host. 
# All interaction with mysqld must be made via Unix sockets or named pipes. 
# Note that using this option without enabling named pipes on Windows 
# (via the "enable-named-pipe" option) will render mysqld useless! 
# 
# commented in by xampp security 


# Replication Master Server (default) 
# binary logging is required for replication 
# log-bin deactivated by default since XAMPP 1.4.11 
#log-bin=mysql-bin 

# required unique id between 1 and 2^32 - 1 
# defaults to 1 if master-host is not set 
# but will not function as a master if omitted 
server-id = 1 

# Replication Slave (comment out master section to use this) 
# 
# To configure this host as a replication slave, you can choose between 
# two methods : 
# 
# 1) Use the CHANGE MASTER TO command (fully described in our manual) - 
# the syntax is: 
# 
# CHANGE MASTER TO MASTER_HOST=<host>, MASTER_PORT=<port>, 
# MASTER_USER=<user>, MASTER_PASSWORD=<password> ; 
# 
# where you replace <host>, <user>, <password> by quoted strings and 
# <port> by the master's port number (3306 by default). 
# 
# Example: 
# 
# CHANGE MASTER TO MASTER_HOST='125.564.12.1', MASTER_PORT=3306, 
# MASTER_USER='joe', MASTER_PASSWORD='secret'; 
# 
# OR 
# 
# 2) Set the variables below. However, in case you choose this method, then 
# start replication for the first time (even unsuccessfully, for example 
# if you mistyped the password in master-password and the slave fails to 
# connect), the slave will create a master.info file, and any later 
# change in this file to the variables' values below will be ignored and 
# overridden by the content of the master.info file, unless you shutdown 
# the slave server, delete master.info and restart the slaver server. 
# For that reason, you may want to leave the lines below untouched 
# (commented) and instead use CHANGE MASTER TO (see above) 
# 
# required unique id between 2 and 2^32 - 1 
# (and different from the master) 
# defaults to 2 if master-host is set 
# but will not function as a slave if omitted 
#server-id  = 2 
# 
# The replication master for this slave - required 
#master-host  = <hostname> 
# 
# The username the slave will use for authentication when connecting 
# to the master - required 
#master-user  = <username> 
# 
# The password the slave will authenticate with when connecting to 
# the master - required 
#master-password = <password> 
# 
# The port the master is listening on. 
# optional - defaults to 3306 
#master-port  = <port> 
# 
# binary logging - not required for slaves, but recommended 
#log-bin=mysql-bin 


# Point the following paths to different dedicated disks 
#tmpdir  = /tmp/  
#log-update  = /path-to-dedicated-directory/hostname 

# Uncomment the following if you are using BDB tables 
#bdb_cache_size = 4M 
#bdb_max_lock = 10000 

# Comment the following if you are using InnoDB tables 
#skip-innodb 
innodb_data_home_dir = /opt/lampp/var/mysql/ 
innodb_data_file_path = ibdata1:10M:autoextend 
innodb_log_group_home_dir = /opt/lampp/var/mysql/ 
# You can set .._buffer_pool_size up to 50 - 80 % 
# of RAM but beware of setting memory usage too high 
innodb_buffer_pool_size = 16M 
# Deprecated in 5.6 
#innodb_additional_mem_pool_size = 2M 
# Set .._log_file_size to 25 % of buffer pool size 
innodb_log_file_size = 5M 
innodb_log_buffer_size = 8M 
innodb_flush_log_at_trx_commit = 1 
innodb_lock_wait_timeout = 50 

[mysqldump] 
quick 
max_allowed_packet = 16M 

[mysql] 
no-auto-rehash 
# Remove the next comment character if you are not familiar with SQL 
#safe-updates 

[isamchk] 
key_buffer = 20M 
sort_buffer_size = 20M 
read_buffer = 2M 
write_buffer = 2M 

[myisamchk] 
key_buffer = 20M 
sort_buffer_size = 20M 
read_buffer = 2M 
write_buffer = 2M 

[mysqlhotcopy] 
interactive-timeout 

!include /opt/lampp/mysql/my.cnf  

あなたはskip-external-lockingがコメントアウトされており、何のskip-networkingラインが存在しないことがわかりますです。サーバーが任意のIPアドレスからの接続を受け入れるように、bind-address0.0.0.0に設定されています。私がに接続しようとすると、私は上記のコマンドの両方が正常に動作し、私を可能にします

mysql -h localhost -u root -p 
mysql -h 10.120.42.70 -u root -p 

がサーバー

にログインRHELのマシンの中からこれを使用してMySQLサーバにログインすることができる午前

このような私のローカルのWindowsマシンからサーバー:

mysql -h 10.120.42.70 -u root -p 

それはパスワードを要求し、私はパスワードを与えるが、私はエラーを取得しています:

ERROR 2003 (HY000): Can't connect to MySQL server on '10.120.42.70' (10060 "Unknown error")

ユーザー 'root'の権限を付与しました。それでも私は同じエラーが発生しています。私のRHELリモートマシンで

、私はnetstatを実行し、私はこれを取得:

sudo netstat -lntp | grep 3306 
    tcp  0  0 0.0.0.0:3306   0.0.0.0:*     LISTEN  16323/mysqld 

だから、MySQLサーバは間違いなくすべてのIPアドレスに3306でリッスンしています。なぜ私はまだそれを遠隔からアクセスすることができないのだろうか?

+0

この問題は、私が抱えている問題と同様に聞こえるので解決しましたか? – Mathew

答えて

0

ユーザー 'root' @ 'localhost'の権限を付与しましたか?もしそうなら、それらを 'root' @ '%'に与えてください。 MySQLはユーザ名とホスト名でユーザを識別します。別のマシンから接続する場合、rootユーザーはroot @ localhostではなくroot @ somehostとして識別されます。

+1

この回答はOPの問題には適用されません。 ''10 .120.42.70 'のMySQLサーバーに接続できないというのは、ネットワーク関連の問題を意味します。あなたの場合は、アクセス許可について何か言います。 – rkosegi

+0

しました。これは私が使用したSQLクエリであり、エラーなしで実行されたものです 'root' @ '%' IDENTIFIED BY 'mypassword' – technOslerphile

1

Windowsクライアントからping RHELサーバーを使用できる場合は、ほとんどファイアウォールの問題であることがわかります。 MSDNから

10060 Connection timed out.

A connection attempt failed because the connected party did not properly respond after a period of time, or the established connection failed because the connected host has failed to respond.

一時的禁止ファイアウォールに試してみてください。RHEL 6の場合

RHEL 7の場合
service iptables stop 

systemctl stop iptables 

または

systemctl stop firewalld 

ことに役立ちます場合は、ファイアウォールのコマンドが助け、私はあなたを指すことができますについての詳細を提供ファイアウォールにルールを追加する方法を教えてください。をもう一度有効にしてください。

UPDATE

可能な回避策は、(リモートSSHサーバーで許可されていれば)、SSHを介してTCPトンネリングを使用することです。

ssh [email protected] -L 5000:127.0.0.1:3306

これは次のようにMySQLサーバに接続し、リモートのlocalhostのポートにポート5000を3306

をローカルクライアントマシンからの接続を転送します:あなたが代わりに同様のローカルポートを選択することができますmysql -uroot -h localhost:5000 -p

5000

+0

sudoサービスのiptablesステータスを確認したところ、 'Firewall is走っていない' 。だから私はこれが問題ではないと推測しています。とにかく、私はiptablesサービスを停止しようとした後、私のローカルからMySQLサーバーに接続しようとしました。それでも私に同じエラーが出る – technOslerphile

+0

@technOslerphile:他のクライアントからMySQLに接続できますか? WindowsからRHEL上のSSHに接続できますか? – rkosegi

+0

はい、できます。私はsshを使ってすべてのサーバー構成の編集を行います。 – technOslerphile

関連する問題