mysql能远程链接不上去_Mysql 在本地能连接上,远程链接不上的解决办法

在阿里云服务器 ECS上,安装完MySQL数据库后,在本地能连接上,远程连接不上,一直报10060的错误,如下图:

31fb818f1a9db264c81024710b209992.png

工具/原料

阿里云服务器 ECS

安装MySQL

方法/步骤

1.查看MySQL进程是否正常,可以阿里云服务器 ECS 服务器上输入:ps -ef|grep mysqld

mysqld_safe和mysqld都在,说明MySQL进程是正常,若没有这两进程,执行/etc/init.d/mysqld start,启动msyql。

2.查看mysql监听IP和端口是否正常。

使用:netstat -anpt

监听得地址如果是:::3306或者是0.0.0.0:3306,表示监听所有IP地址,这监听状态是正常。若出现127.0.0.0:3306,说明监听的本地地址,需要在mysql配置文件中将bind-address选项设置为bind-address = 0.0.0.0,重启mysql。

mysql能远程链接不上去_Mysql 在本地能连接上,远程链接不上的解决办法_第1张图片

3.查看用于远程访问的mysql用户权限是否正确。

在本地登入mysql服务器,

use mysql;

SELECT user, host from mysql.user; 查看用于远程访问的mysql用户host的权限,%表示允许所有机器访问。若host为127.0.0.1/localhost,那么这个用户就只能本机访问,则需要将host改为%,可以使用update user set host='%' where user='root';

mysql能远程链接不上去_Mysql 在本地能连接上,远程链接不上的解决办法_第2张图片

76f603f4e3b17315a856707da45b396d.png

4.

若以上操作都正常,还是远程还是不能访问的话,可以使用tcpdump在服务器端抓一下3306端口,看是否有数据包,排查以下网络原因。

在服务上输入抓包命令:tcpdump port 3306

然后远程连接mysql数据库,看一下服务端是否有数据包。

1a9672d4ae7b610e503f01970ba07422.png

5.如果没有数据包,查一下阿里云服务器 ECS下的安全组件中的配置

mysql能远程链接不上去_Mysql 在本地能连接上,远程链接不上的解决办法_第3张图片

6.若安全组件中的配置中,入口未对数据库服务监听的3306端口放开,则需要将3306端口放开。如下图,并没有3306端口,则表示未放开该端口。

mysql能远程链接不上去_Mysql 在本地能连接上,远程链接不上的解决办法_第4张图片

mysql能远程链接不上去_Mysql 在本地能连接上,远程链接不上的解决办法_第5张图片

7.在阿里云服务器 ECS下的安全组件中的配置,放开3306端口。单击添加安全组规则,如下图:mysql能远程链接不上去_Mysql 在本地能连接上,远程链接不上的解决办法_第6张图片

mysql能远程链接不上去_Mysql 在本地能连接上,远程链接不上的解决办法_第7张图片

以上操作基本上可以排查问题得所在原因了

你可能感兴趣的:(mysql能远程链接不上去)