主页 > 知识库 > docker容器访问宿主机的MySQL操作

docker容器访问宿主机的MySQL操作

热门标签:株洲电销 贵阳网络外呼系统软件 宿州外呼系统公司 陕西办理400电话 地图标注小程序 信阳电销外呼系统怎么样 南充电销外呼系统 海外工厂地图标注 南昌外呼系统定制

背景:

有一个flask项目提供接口,使用docker容器构建并且运行,MySQL在宿主机运行,需要在容器中可以让flask连接上宿主机的mysql

使用ifconfig命令可以看到,有一个docker0和eth0,在docker容器中可以通过eth0的IP地址加上端口号(3306)这样就可以连接上宿主机的MySQL了;另外,nginx可以通过docker0的IP地址加上构建容器时指定的端口号进行访问容器。

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

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

我在docker上面执行docker ps显示如下:

说明我的mysql是正常的,但是我用sqlyog和Navicat都无法连接我的数据库,后来才发现问题所在,之前我在创建mysql容器(docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d mysql:5.6.35)时候虽然成功,但是有一句提示我疏忽了:

这里提示网络不可用,所以宿主机无法连接数据库

解决办法:现在输入这个命令vim /usr/lib/sysctl.d/00-system.conf(vim不行的话你就输入vi):

马上会出现这个:

在末尾添加这句: 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 如下:

现在你可以重新创建mysql的容器了,看下效果:

是不是没有那个网络不可用的警告了;我用sqlyog连接的,用Navicat连也一样:

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

标签:开封 晋城 石嘴山 三明 玉林 汕头 拉萨 郑州

巨人网络通讯声明:本文标题《docker容器访问宿主机的MySQL操作》,本文关键词  docker,容器,访问,宿,主机,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《docker容器访问宿主机的MySQL操作》相关的同类信息!
  • 本页收集关于docker容器访问宿主机的MySQL操作的相关信息资讯供网民参考!
  • 推荐文章