docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦

docker运行mysql容器正常,宿主机Navicat却无法连接

我在docker上面执行docker ps显示如下:
docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦
说明我的mysql是正常的,但是我用sqlyog和Navicat都无法连接我的数据库,后来才发现问题所在,之前我在创建mysql容器(docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d mysql:5.6.35)时候虽然成功,但是有一句提示我疏忽了:
docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦
这里提示网络不可用,所以宿主机无法连接数据库
解决办法:现在输入这个命令vim /usr/lib/sysctl.d/00-system.conf(vim不行的话你就输入vi):
docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦
马上会出现这个:
docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦
在末尾添加这句: net.ipv4.ip_forward=1 (添加的指令是这样:先按i 键,接着你就可以操作了)然后保存退出(写好了net.ipv4.ip_forward=1这个命令按esc键,接着Ctrl+: 最后输入wq! 你就保存退出了),你再重启network服务: systemctl restart network 先把刚才那个mysql的容器停止docker stop docker ,再把容器删了docker rm mysql 如下:
docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦
现在你可以重新创建mysql的容器了,看下效果:
docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦
是不是没有那个网络不可用的警告了;我用sqlyog连接的,用Navicat连也一样:
docker的mysql容器运行正常,但是宿主机却连不上数据库,解决方法来啦