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的用户名和密码