数据库
首页 > 数据库> > NAVICAT无法连接到CENTOS中DOCKER容器内的MYSQL;报错10038;服务器端口访问被拒绝。

NAVICAT无法连接到CENTOS中DOCKER容器内的MYSQL;报错10038;服务器端口访问被拒绝。

作者:互联网

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

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

先在CENTOS上把容器运行起来:
docker pull mysql:8.0
docker run -di --name=mysql_a -p 3306:3306  -e MYSQL_ROOT_PASSWORD=123456 mysql

 

docker exec -it mysql_a /bin/bash
mysql -uroot -p123456

 

grant all privileges on *.* to root@'%' with grant option;  
flush privileges;

 

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

 

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY  '123456';

 

use mysql ;  select user,host,authentication_string,plugin from user;

在这里插入图片描述

他表示改好了

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

启动防火墙:systemctl start firewalld
关闭防火墙:systemctl stop firewalld
检查防火墙状态:systemctl status firewalld 

 

 

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

在这里插入图片描述

这根本没开的嘛。。

	1. 先安装包命令包:
yum install net-tools
	2.检查端口使用情况,只看tcp的:
netstat -nplt 

 

 

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

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

telnet 47.94.239.23 3306

 

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

于是又登陆服务器:

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

sysctl net.ipv6.bindv6only

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

sysctl net.ipv4.ip_forward

 

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

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

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

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

在这里插入图片描述

终于成功连上了,简直多舛。

标签:容器,服务器端,CENTOS,端口,防火墙,报错,mysql,3306
来源: https://www.cnblogs.com/minimeta/p/16504267.html