• 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。连接正常

  • 相关阅读:
    Asp.Net Core中Session使用
    服务器开发- 牌和牌的基本操作
    服务器开发- Asp.Net Core中的websocket,并封装一个简单的中间件
    Lua Table转C# Dictionary
    Asp.Net Core 2.1+的视图缓存(响应缓存)
    C#中await和async关键字的简单理解
    SQLSERVER中分割字符串成多列
    Asp.Net Core Identity+EFCore + Mysql踩坑记录
    小试牛刀2:JavaScript基础题
    CSS典型案例实践
  • 原文地址:https://www.cnblogs.com/ziroro/p/9479869.html
Copyright © 2020-2023  润新知