Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 65843|回复: 0

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

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-9 11:06:42 | 显示全部楼层 |阅读模式

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

    开放Mysql的远程连接

    在服务器上登录mysql,然后执行以下的命令。

    登录mysql:

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

    执行赋权的命令:

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

    也可以直接重启mysql。

    1. /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端口。

    1. vi /etc/sysconfig/iptables
    2.  
    3. # Firewall configuration written by system-config-firewall
    4. # Manual customization of this file is not recommended.
    5. *filter
    6. :INPUT ACCEPT [0:0]
    7. :FORWARD ACCEPT [0:0]
    8. :OUTPUT ACCEPT [0:0]
    9. -A INPUT -p tcp -m tcp --dport 10100:10180 -j ACCEPT
    10. -A INPUT -p tcp -m tcp --dport 21 -j ACCEPT
    11. -A INPUT -p tcp -m tcp --dport 80 -j ACCEPT
    12. -A INPUT -p tcp -m tcp --dport 3306 -j ACCEPT
    13. -A INPUT -j REJECT reject-with icmp-host-prohibited
    14. -A FORWARD -j REJECT reject-with icmp-host-prohibited
    15. COMMIT

    重启防火墙

    1. /etc/init.d/iptables restart

    检查my.cnf

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

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

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

    1. #skip-networking

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

    1. #bind-address = 127.0.0.1

    或者指定允许访问的ip

    1. #bind-address = 192.168.1.2

    然后重启mysql。

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

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

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

    附录iptables防火墙的命令

    查询防火墙状态:

    1. [root@localhost ~]# service iptables status

    停止防火墙:

    1. [root@localhost ~]# service iptables stop

    启动防火墙:

    1. [root@localhost ~]# service iptables start

    重启防火墙:

    1. [root@localhost ~]# service iptables restart

    永久关闭防火墙:

    1. [root@localhost ~]# chkconfig iptables off

    永久关闭后启用:

    1. [root@localhost ~]# chkconfig iptables on

    编辑防火墙规则

    1. vi /etc/sysconfig/iptables

    重启防火墙的其他方式

    1. /etc/init.d/iptables restart

    结束

    你学会了吗?

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-12-22 13:45 , Processed in 0.059402 second(s), 27 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表