Naicat连接本地CentOS 7虚拟机上的MySQL数据库失败解决办法


注意:Navicat主机栏填的是Centos虚拟机的IP地址

一、检查mysql容器

确保网络正常、保证mysql容器处于运行中且用户名、密码和端口正确。

1、查看mysql容器是否运行

bash 复制代码
docker ps

2、查看mysql容器详细信息,可查看端口

bash 复制代码
docker inspect mysql

二、检查防火墙:

1、如果您在使用 Linux 服务器,确保防火墙设置没有阻止外部访问 3306 端口。可以用以下命令查看当前防火墙设置:

bash 复制代码
firewall-cmd --list-all

2、如果发现 3306 端口未开放,可以添加规则:

bash 复制代码
firewall-cmd --zone=public --add-port=3306/tcp --permanent

3、避免添加完的端口未能被识别,执行了 firewall-cmd --reload 命令,以使更改生效:

bash 复制代码
firewall-cmd --reload
防火墙配置分析

Zone: public (active)

当前活动的区域是 public,这通常表示适用于外部网络连接。

Target: default

目标策略为 default,这意味着如果没有其他规则匹配,则将应用默认行为。

Interfaces: ens33

防火墙当前配置与接口 ens33 相关联,这通常是您的网络接口。

Services: dhcpv6-client ssh

允许的服务包括 DHCPv6 客户端和 SSH。这意味着您可以通过 SSH 远程访问此机器。

Ports: (empty)

没有特别开放的端口。这是问题的关键所在,MySQL 的默认端口 3306 没有被列出,意味着它不能接受外部连接。

Protocols: (empty)

没有额外指定的协议。

Masquerade: no

没有启用 IP 伪装,这通常在 NAT 配置中使用。

Forward-ports: (empty)

没有配置端口转发规则。

Source-ports: (empty)

没有源端口的配置。

ICMP-blocks: (empty)

没有被阻止的 ICMP 协议。

Rich rules: (empty)

没有任何富规则(高级规则)。

相关推荐
倔强的石头_16 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
xy123061 天前
OpenStack Train 部署实战(三)控制节点--keystone服务
centos·openstack
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker