如何解决远程连接mysql出现Can't connect to MySQL server on (111 "Connection refused")的问题

本文详细介绍了如何解决在远程连接MySQL服务器时遇到的Connection refused错误。通过调整MySQL权限、重启服务、修改防火墙规则及my.cnf配置,确保远程访问畅通无阻。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如何解决远程连接mysql出现Can’t connect to MySQL server on (111 “Connection refused”)的问题

Mysql的远程连接,当配置完账号权限后,却发现远程连接的时候出现

Can't connect to MySQL server on (111 "Connection refused")

的问题,经过排查解决了这个问题。下面是步骤。 开放Mysql的远程连接 在服务器上登录mysql,然后执行以下的命令。 登录mysql

/usr/local/mysql-5.6/bin/mysql -u root -p

执行赋权的命令:

MySQL> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'IDENTIFIED BY '123456' WITH GRANT OPTION; 
MySQL> flush privileges;

也可以直接重启mysql。

/usr/local/mysql-5.6/support-files/mysql.server restart

远程连接Mysql

在本地连接mysql,我们可以使用mysql workbench,这是一款英文的mysql的客户端。

连接的时候出现错误:Can't connect to MySQL server on Ip地址 (111 "Connection refused")

检查防火墙 先检查防火墙的3306端口是不是放开了。这台服务器使用的是iptables,打开iptables,配置3306端口。

vi /etc/sysconfig/iptables
# Firewall configuration written by system-config-firewall
# Manual customization of this file is not recommended.
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -p tcp -m tcp --dport 10100:10180 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 21 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 80 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 3306 -j ACCEPT
-A INPUT -j REJECT –reject-with icmp-host-prohibited
-A FORWARD -j REJECT –reject-with icmp-host-prohibited
COMMIT

重启防火墙

/etc/init.d/iptables restart

检查my.cnf

my.cnf的配置文件中,有参数控制它是否运行在网络上。例如查看这个my.cnf

vi /usr/local/mysql-5.6/my.cnf

如果是老的版本,使用#屏蔽skip-networking,如下。

#skip-networking

如果是新的版本,使用#屏蔽bind-address

#bind-address  = 127.0.0.1

或者指定允许访问的ip

#bind-address  = 192.168.1.2

然后重启mysql

/usr/local/mysql-5.6/support-files/mysql.server restart

这里是用文件的方式来启动mysql,你可以用服务的方式。

叶子在屏蔽#skip-networking后,再远程连接mysql就OK了。

附录iptables防火墙的命令

查询防火墙状态:

[root@localhost ~]# service   iptables status

停止防火墙:

[root@localhost ~]# service   iptables stop

启动防火墙:

[root@localhost ~]# service   iptables start

重启防火墙:

[root@localhost ~]# service   iptables restart

永久关闭防火墙:

[root@localhost ~]# chkconfig   iptables off

永久关闭后启用:

[root@localhost ~]# chkconfig   iptables on

编辑防火墙规则

vi /etc/sysconfig/iptables

重启防火墙的其他方式

/etc/init.d/iptables restart

来源:http://www.wordpressleaf.com/2017_1703.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值