1. 直接连接mysql服务器3306端口

3306端口无法远程访问的解决方案

a.网络检测

1)ping 主机的ip地址 
— 如果ping不通,说明你的网络有问题,可以搜索解决网络问题的方案

2)telnet 主机ip地址 3306 
— 如果显示无法连接,则可能是网络问题,也可能是其它问题,需要下面的步骤继续排查

3)telnet 主机ip地址 22 
— 如果无法连接,可能是你的主机没有安装ssh-server(一般系统只默认安装ssh-client); 
— 也可能是防火墙把22端口禁用,不一定是网络问题(这一步仅和上一步做对比; 
— 如果能够连接,说明网络没有问题,而是你的主机配置问题,然后按以下步骤继续排查)

b.端口检测

1) netstat -ntpl | grep 3306 
tcp 0 0 127.0.0.1:3306 127.0.0.1:* LISTEN -

2) netstat -ntpl | grep 22 
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN -

3)结论 
— :::3306 0.0.0.0:22 都是表明允许任意ip访问(:::3306的结论是根据结果推测,不保证正确) 
— 127.0.0.1:3306 表示仅允许本机访问

— 对于端口只允许本机访问,可以查看两个地方的配置: 
1.防火墙对3306端口进行了限制,针对这种情况下面c项说明了解决方案 
2.mysql配置绑定本机地址,针对这种情况下面的d项说明了解决方案

c.防火墙检测

— ubuntu下使用ufw工具 
sudo ufw status 查看防火墙状态,在ubuntu下iptables一般被ufw接管,而selinux是默认不安装的,如果你曾经安装过,就需要禁用seliux并重启系统了。 
sudo ufw enable/disable 启用和禁用防火墙 
sudo ufw allow 3306 允许访问3306端口

— 以下是centos等系统的做法: 
1)iptables –list查看; 
2)开启防火墙3306端口 
vim /etc/sysconfig/iptables 
-A INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT(允许3306端口通过防火墙) 
/etc/init.d/iptables restart(重启防火墙使配置生效) 
3)或者直接关闭防火墙; 
参考:

d.mysql配置文件检查

检查my.cnf的配置,bind-address=addr可以配置绑定ip地址。 
不配置或者IP配置为0.0.0.0,表示监听所有客户端连接。

— 如何查找my.cnf配置文件: 
ps -aux | grep mysql 查看进程ID是3340 
ll /proc/3340 查看进程程序情况,找配置文件 
或者#which mysql 找程序路径

e.mysql用户访问权限

进入mysql数据库

$mysql -u root -p
>use mysql;
>select host,user from user;



MySQL建用户的时候会指定一个host,默认是127.0.0.1/localhost只能本机访问; 
其它机器用这个用户帐号访问会提示没有权限,host改为%,表示允许所有机器访问。

例如: 你想myuser使用mypassword(密码)从任何主机连接到mysql服务器的话。

  mysql>GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%'IDENTIFIED BY 'mypassword' WITH GRANT OPTION;

  如果你想允许用户myuser从ip为192.168.1.6的主机连接到mysql服务器,并使用mypassword作为密码

  mysql>GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3'IDENTIFIED BY

  'mypassword' WITH GRANT OPTION;

   mysql>FLUSH PRIVILEGES

  使修改生效,就可以了

2.ssh通道

mysql服务器安装了ssh-server,并开放了22端口

a.ssh配置项中ip为mysql服务器ip 
b.用户名和密码是mysql服务器主机的用户名和密码 
c.mysql配置项为mysql的用户名和密码

3.http通道

mysql服务器搭建了web服务器,以lnmp环境为例。

a.把数据库连接工具安装根目录下的ntunnel_mysql.php文件拷贝到mysql服务器的web服务器根目录。 
b.通道地址http://mysql服务器ip或域名/ntunnel_mysql.php 
c.用户名为mysql服务器主机的用户名和密码 
d.mysql配置项为mysql的用户名和密码