navicat无法连接到CentOS中Docker容器内的Mysql;报错10038;服务器端口访问被拒绝。

问题:在服务器上用docker配值好MySQL8.0的容器后,本地navicat无法连接。

解决过程记录,最后的解决方法是在安全组策略那里进行配置。

先在CentOS上把容器运行起来:
  • 下载镜像
docker pull mysql:8.0
  • 创建容器,设置端口映射3306-3306
docker run -di --name=mysql_a -p 3306:3306  -e MYSQL_ROOT_PASSWORD=123456 mysql
  • 进入容器启动mysql
docker exec -it mysql_a /bin/bash
  • 登陆
mysql -uroot -p123456
  • 让root可被所有ip链接,完了刷新限权
grant all privileges on *.* to root@'%' with grant option;  
flush privileges;
  • mysql8.0的版本和以前5的版本加密方式不一样,之前被坑过一次导致navicat无法连接上。这里先把这坑填了,将密码修改并改为之前的native加密方式。
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
  • 上一步是让远程客户端连接数据库密码被修改了,实际上内部还是原来的加密方式,同样也修改一下,让容器内部的登陆密码也变成native加密方式。
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY  '123456';
  • 检查用户信息是否修改成功:
use mysql ;  select user,host,authentication_string,plugin from user;

在这里插入图片描述

他表示改好了

  • 这个时候用本地navicat尝试进行连接:

在这里插入图片描述
我果然不可能这么顺利…看的很多教程好像到这一步就完了,而且成功连接上了。。

  • 之后各种百度,说可能是CentOS防火墙请求给过滤了,于是尝试关闭防火墙:
启动防火墙:systemctl start firewalld
关闭防火墙:systemctl stop firewalld
检查防火墙状态:systemctl status firewalld 

结果检查我的防火墙状态:

在这里插入图片描述

这根本没开的嘛。。

  • 于是又各种百度,有网友说可能是容器的映射端口失败,centos根本没有配分端口,或者分配错误。于是立马下包检查:
	1. 先安装包命令包:
yum install net-tools
	2.检查端口使用情况,只看tcp的:
netstat -nplt 

在这里插入图片描述
发现端口也是开启的,没毛病的嘛…

  • 这时候突然看到这个3306端口的进程使用的是IPv6协议,于是想到有没有可能是我发送的ipv4协议请求无法被正确解析。

于是使用本地机器win10的命令【telnet ip 端口号】 对远程服务器的3306端口进行测试:
这个需要win10本地设置开启telnet服务,具体设置可以百度到。

telnet 47.94.239.23 3306

结果3306无法连通。
在这里插入图片描述
而我对ipv4的22端口测试发现是能够连通的。

  • 于是猜想可能是服务器没有正确设置ipv4转为ipv6。

于是又登陆服务器:

看看应用程序是否只能bind在ipv6上面:

sysctl net.ipv6.bindv6only

结果:
在这里插入图片描述
看看ipv4是否能够转发:

sysctl net.ipv4.ip_forward

结果:在这里插入图片描述
1 表示能转发 ;0表示不能转发

口区,结果又都是正常的。。

  • 最后,在一篇博客上看到,阿里云的服务器还有一个叫安全组的东西。

这个东类似于防火墙,都是通过iptable组件来过滤ip。
于是打开我的阿里云的控制台,打开安全组策略。
在这里插入图片描述
发现里面默认只有开放端口22,但没有包含3306的端口范围,突然也明白了之前telnet测试为什么只有22号端口能够连通,3306无法连通。

于是手动添加一个入方向的安全组策略,端口范围设置为3306/3306,然后保存关网页,用navicat测试:

在这里插入图片描述

终于成功连上了,简直多舛。
<think>好的,我现在需要帮用户在CentOS 7上通过Docker安装MySQL。首先,我得回忆一下Docker的基本操作步骤。用户可能不太熟悉Docker,所以步骤要详细一点。 首先,安装Docker本身是前提。CentOS 7默认的仓库里可能有旧版本的Docker,所以应该先添加Docker的官方仓库,然后安装。记得启动Docker服务,并设置开机启动,这样下次重启后Docker会自动运行。 接下来是拉取MySQL镜像。用户可能想要特定版本,比如5.7,所以需要指定标签。不过用户示例中的引用提到可以使用`centos/mysql-57-centos7`,或者官方的MySQL镜像。可能得确认一下哪个更合适。不过官方镜像通常更新更及时,所以建议使用`mysql:5.7`。 然后是运行容器。这里需要注意端映射和数据卷。用户可能需要将MySQL的3306端映射到宿主机的端,比如默认的3306,但如果有冲突的话,可能需要调整。数据持久化是关键,所以要用-v参数把容器里的数据目录挂载到宿主机,防止容器删除后数据丢失。设置root密码也是必须的,通过环境变量MYSQL_ROOT_PASSWORD来配置。 还有,用户可能需要远程访问MySQL,所以需要检查MySQL的配置,确保允许远程连接。可能需要进入容器修改用户权限,或者创建新用户并授权。引用中提到的进入容器的方法是用docker exec,这步可能需要指导用户如何操作。 另外,用户可能会遇到安装失败的情况,比如已有的MySQL服务冲突,或者权限问题。需要提醒用户检查是否宿主机已经安装了MySQL,如果有的话需要先停止或卸载,否则端冲突会导致容器无法启动。还有,如果拉取镜像失败,可能需要检查网络,或者换一个镜像源。 最后,测试连接部分,用户可能需要使用命令行或者客户端工具,比如mysql命令或者Navicat。要确保防火墙开放了对应的端CentOS 7的firewalld需要配置,或者直接关闭防火墙测试。 总的来说,步骤大概是:安装Docker -> 拉取镜像 -> 运行容器 -> 配置远程访问 -> 测试连接。需要按顺序写清楚每个步骤的命令和注意事项,同时引用相关的参考资料,比如引用1、2、5关于拉取镜像和运行容器,引用3进入容器的方法,引用4处理安装失败的情况。</think>### 在CentOS 7中使用Docker安装MySQL的步骤 #### 1. **安装Docker** - 若未安装Docker,需先安装并启动服务: ```bash # 安装依赖包 sudo yum install -y yum-utils device-mapper-persistent-data lvm2 # 添加Docker仓库 sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo # 安装Docker引擎 sudo yum install -y docker-ce docker-ce-cli containerd.io # 启动Docker并设置开机自启 sudo systemctl start docker sudo systemctl enable docker ``` #### 2. **拉取MySQL镜像** - 以MySQL 5.7为例,拉取官方镜像[^5]: ```bash docker pull mysql:5.7 ``` - 或使用CentOS兼容的镜像[^1]: ```bash docker pull centos/mysql-57-centos7 ``` #### 3. **创建并运行MySQL容器** - 使用以下命令启动容器: ```bash docker run -d \ --name mysql \ -p 3306:3306 \ -e MYSQL_ROOT_PASSWORD=your_password \ -v /宿主机数据目录:/var/lib/mysql \ mysql:5.7 ``` - `-p 3306:3306`:将容器映射到宿主机[^3] - `-v`:挂载数据卷实现持久化存储[^2] - `-e MYSQL_ROOT_PASSWORD`:设置root用户密码[^5] #### 4. **配置远程访问(可选)** - 进入容器并修改权限: ```bash docker exec -it mysql /bin/bash # 进入容器 mysql -u root -p # 输入密码登录 ``` - 执行SQL命令允许远程连接: ```sql ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'your_password'; FLUSH PRIVILEGES; ``` #### 5. **验证安装** - 查看容器运行状态: ```bash docker ps ``` - 测试连接: ```bash mysql -h 127.0.0.1 -P 3306 -u root -p ``` #### 常见问题处理 1. **端冲突** - 若宿主机已安装MySQL,需先停止服务或修改映射端(如`-p 3307:3306`)[^4]。 2. **容器启动失败** - 检查日志定位问题: ```bash docker logs mysql ``` 3. **权限问题** - 确保数据目录权限正确: ```bash chmod -R 755 /宿主机数据目录 ``` ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值