一.问题的提出


/usr/local/webserver/mysql/bin/mysql -u root -h 172.29.141.112 -p -S /tmp/mysql.sock
Enter password:
ERROR 2003 (HY000): Can't connect to MySQL server on '172.29.141.112' (113)


二.问题的分析


出现上述问题,可能有以下几种可能


1. my.cnf 配置文件中 skip-networking 被配置

skip-networking 这个参数,导致所有TCP/IP端口没有被监听,也就是说出了本机,其他客户端都无法用网络连接到本mysql服务器

所以需要把这个参数注释掉。


2.my.cnf配置文件中 bindaddress 的参数配置

bindaddress,有的是bind-address ,这个参数是指定哪些ip地址被配置,使得mysql服务器只回应哪些ip地址的请求,所以需要把这个参数注释掉。


3.防火墙的原因

通过 /etc/init.d/iptables stop 关闭防火墙

我的问题,就是因为这个原因引起的。关闭mysql 服务器的防火墙就可以使用了。


三.问题的解决

1. 如果是上述第一个原因,那么 找到 my.cnf ,注释掉 skip-networking 这个参数

sed -i 's%skip-networking%#skip-networking%g' my.cnf


2. 如果是上述第二个原因,那么 找到 my.cnf ,注释掉 bind-address 这个参数

sed -i 's%bind-address%#bind-address%g' my.cnf

sed -i 's%bindaddress%#bindaddress%g' my.cnf


最好修改完查看一下,这个参数。


3.如果是上述第三个原因,那么 把防火墙关闭,或者进行相应配置


/etc/init.d/iptables stop