docker部署mysql无法远程连接2003解决

背景

最近使用 docker,故将数据库和程序都用 docker 来一遍。在部署 mysql 时,本地连接访问正常,但是远程访问却提示2003或超时。网上找了一圈下来,发现全是一些复制粘贴的,更有甚者连字母都拼不全的。按照那个思路,应该离入门到放弃不远了。故特意写这篇文章,帮大家去真正的解决问题。

1. docker 安装 mysql8 版本

# docker 中下载 mysql docker pull mysql #启动 docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql #进入容器 docker exec -it mysql bash #登录mysql mysql -u root -p ALTER USER 'root'@'localhost' IDENTIFIED BY '123456'; #添加远程登录用户 CREATE USER 'admin'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; GRANT ALL PRIVILEGES ON *.* TO '123456'@'%';

2. 检查端口是否通信

利用 telnet [ip] [port]命令进行IP和端口检查

3. 检查防火墙

centos下

systemctl status firewalld systemctl stop firewalld

ubuntu下

sudo ufw status sudo ufw enable|disable

4. 检查监听端口

使用netstat命令检查3306端口是否监听状态

netstat -nlt | grep 3306

docker部署mysql无法远程连接2003解决插图

可以看出,这里采用的是 ipv4 和 ipv6 通信

5. 检查 ipv4 和 ipv6

执行下述代码,查看他们的状态

sysctl net.ipv6.conf.all.forwarding sysctl net.ipv4.conf.all.forwarding

如果得到 net.ipv4.conf.all.forwarding=0,那么需要将对应的值修改为1

sysctl net.ipv4.conf.all.forwarding=1

6. 重启 docker 服务

sudo systemctl restart docker

最后,连接一下mysql

mysql -h xxxx -u root -p

docker部署mysql无法远程连接2003解决插图1

至此,无法远程连接的问题已经解决了。

原文链接:https://blog.csdn.net/zulien/article/details/127574465?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522171836884016800178552552%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fblog.%2522%257D&request_id=171836884016800178552552&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~blog~first_rank_ecpm_v1~times_rank-19-127574465-null-null.nonecase&utm_term=docker%E9%83%A8%E7%BD%B2

© 版权声明
THE END
喜欢就支持一下吧
点赞12 分享