CentOS系统的防火墙中开放3306端口以允许MySQL连接(2003 -Can‘t connect to MySQL server on (10038))

连接mysql时候报错2003 -Can't connect to MySQL server on (10038)

原因:centos对敏感端口进行了防火墙阻隔,需要手动将3306端口打开

要在CentOS系统的防火墙中开放3306端口以允许MySQL连接,你需要使用`firewall-cmd`,这是`firewalld`服务的命令行界面。以下是开放3306端口的步骤:

  1. 开启端口:

    sudo firewall-cmd --permanent --zone=public --add-port=3306/tcp

这个命令会将3306端口添加到防火墙规则中,并且`--permanent`标志意味着更改是永久性的。

  1. 重新加载防火墙规则:

    sudo firewall-cmd --reload

重新加载防火墙规则以应用更改。

  1. 检查端口是否开放:

    sudo firewall-cmd --list-ports

这个命令会列出所有开放的端口,你应该能在列表中看到3306/tcp。

如果你的系统正在使用`iptables`而不是`firewalld`,你需要使用`iptables`命令来开放3306端口。以下是使用`iptables`开放端口的方法:

  1. 开启端口:

    sudo iptables -I INPUT -p tcp --dport 3306 -j ACCEPT

  2. **保存防火墙规则**:

不同的系统可能有不同的方法来保存iptables规则。CentOS 7或更高版本可能需要你安装`iptables-services`包以保持这些规则持久化。

复制代码
sudo service iptables save

确保你在正确的防火墙软件上执行相应的命令。如果你不确定你的系统使用的是`firewalld`还是`iptables`,你可以通过检查它们的状态来确定:

复制代码
sudo systemctl status firewalld

或者

复制代码
sudo systemctl status iptables

另外,请确保你有足够的权限来执行这些命令,如果需要,请使用`sudo`来获得超级用户权限。在开启端口之后,确保你的MySQL配置(如`bind-address`)允许远程连接(不是仅仅绑定到127.0.0.1或localhost),并且用户权限正确设置来允许远程访问。

相关推荐
赵优秀一一9 分钟前
Python 工程化基础1:环境(conda)、pip、requirements.txt
linux·开发语言·python
刘~浪地球15 分钟前
数据库与缓存--MySQL 高可用架构设计
数据库·mysql·缓存
风酥糖17 分钟前
chroot的Linux服务配置-当云服务器真正用起来
linux·运维·服务器
木鱼布17 分钟前
安装arm虚机启动失败
linux·运维·arm开发
Deitymoon24 分钟前
linux——网络基础
linux·网络
独小乐29 分钟前
013.定时器之系统Tick实现|千篇笔记实现嵌入式全栈/裸机篇
linux·笔记·单片机·嵌入式硬件·arm
笨笨饿34 分钟前
# 52_浅谈为什么工程基本进入复数域?
linux·服务器·c语言·数据结构·人工智能·算法·学习方法
姜太小白38 分钟前
【Linux】麒麟V10SP3解决网络设备名不匹配问题
linux·运维·服务器
@小博的博客38 分钟前
【Linux探索学习】第六弹:操作系统的概念及冯诺依曼体系结构
linux·学习
青桔柠薯片42 分钟前
Linux 设备驱动开发环境构建与系统启动机制剖析
linux·arm开发·驱动开发·imx6ull