背景
最近使用 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
可以看出,这里采用的是 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
至此,无法远程连接的问题已经解决了。