3306端口不通,不一定是网络的问题

今天,开发需要申请一个账号:test@192.168.84.88 。连接时报了以下错误:

Warning: Using a password on the command line interface can be insecure.
ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.84.87' (111)

 

遇到连接失败,首先就是 ping 192.168.84.87

PING 192.168.84.87 (192.168.84.87) 56(84) bytes of data.
64 bytes from 192.168.84.87: icmp_seq=1 ttl=64 time=0.283 ms
64 bytes from 192.168.84.87: icmp_seq=2 ttl=64 time=0.712 ms

 

既然 ping 192.168.84.87没问题,接下来就是 telnet 3306 端口了

telnet 192.168.84.87 3306
Trying 192.168.84.87...
telnet: connect to address 192.168.84.87: Connection refused

发现端口不通了之后,就可以把锅丢给运维。然后安心的开其他事了。但,事情往往没那么简单,运维说他没有限制 3306 端口。这一会就尴尬了。

 

查看一下 3306 端口是否还在

netstat -nalp | grep 3306

tcp 0 0 127.0.0.1:41758 127.0.0.1:3306 TIME_WAIT -
tcp6 0 0 :::3306 :::* LISTEN 6961/mysqld

发现本地有一个应用,使用 127.0.0.1 可以连接数据库。难道是MySQL做了限制,上网查了下。发现MySQL有一个参数,可以限制 IP连接,就是 bind-address。下面是bind-address的解释

bind-address 是MYSQL用来监听某个单独的TCP/IP连接,只能绑定一个IP地址,被绑定的IP地址可以映射多个网络接口. 可以是IPv4,IPv6或是主机名,但需要在MYSQL启动的时候指定(主机名在服务启动的时候解析成IP地址进行绑定). 默认是"*"

 

接下来就是查看 my.cnf 了,发现还真的有这个参数

bind-address = 127.0.0.1

把他注释了之后,重启MySQL。连接正常

posted @ 2018-08-15 10:17  Ziroro  阅读(12162)  评论(0编辑  收藏  举报