mysql 3306 不通_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。连接正常

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值