解决 mysql 服务器 3306 端口不能远程连接
问题:本机可以通过3306端口连接mysql服务器,但远程不行。
- 网络检测
- ping主机可以;
- telnet 主机3306端口不可以;
- telnet 主机22端口可以;
说明与本机网络没有关系;
- 端口检测
- netstat -ntpl |grep 3306
tcp 0 0 :::3306 :::* LISTEN -
- netstat -ntpl |grep 22
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN -
- 可以看出 22 端口监听所有地址,而 3306 只监听本机地址(绑定了到了本地),所以远程无法访问。
- 对于端口只允许本机访问,有两个地方启用,一个是防火墙启用3306,一个就是mysql配置绑定本机地址。
- 防火墙检测
- iptables --list 查看;
- 开启防火墙 3306 端口
vi /etc/sysconfig/iptables
-A INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT(允许3306端口通过防火墙)
/etc/init.d/iptables restart(重启防火墙使配置生效)
- 或者直接关闭防火墙;
- mysql配置文件检查
- 检查 my.cnf 的配置,bind-address=addr 可以配置绑定ip地址。
- 不配置或者IP配置为 0.0.0.0,表示监听所有客户端连接。
ps -aux | grep mysql 查看进程ID是3340
`ll /proc/3340 查看进程程序情况,找配置文件或者#which mysql 找程序路径
- mysql用户访问权限
- 进入mysql数据库
$mysql -u root -p
>use mysql;
>select host,user from user;
- MySQL 建用户的时候会指定一个 host ,默认是127.0.0.1/localhost 只能本机访问;
- 其它机器用这个用户帐号访问会提示没有权限,host 改为 % ,表示允许所有机器访问。
- 将root用户授权给所以连接:
grant all privileges on . to ‘root’@’%’ identified by ‘xxxxxx’;
最后一个为 mysql 密码
让权限立即生效:flush privileges;
1 条评论
喜剧效果背后暗含深刻社会观察。