Docker:容器内服务访问宿主机中的MySql服务

avatar
作者
猴君
阅读量:1

在平时我们部署项目的时候,如果需要再docker中互相访问可以参考Docker:WARNING: Published ports are discarded when using host network mode 解决方法-CSDN博客

如果部署服务在宿主机,然后需要再docker访问其服务,那我们如何处理呢?

第一种:通过 docker0 的 IP 地址进行访问

1、先在宿主机上查看 docker0 对应的 inet IP 地址
# 如果是 CentOS 或者 Ubuntu ifconfig  # 或者使用 ip addr show docker0 # 假设查看的 docker0 的 ip 地址为:172.18.0.1
2、修改 mysql 的配置文件

保证 mysql 可以被任何 ip 访问,但是一定不能开放 3306 端口,不然外网就可以直接访问 mysql 了,如果不开放允许任何 ip 访问,那么则必须要开放允许 docker 服务容器的 IP 能够访问。(注意这里的 IP 是需要连接宿主机 mysql docker 容器的 IP 不是 docker0 的 IP)

[mysqld] bind-address = 0.0.0.0

第二种:增加 host.docker.internal 到 hosts 文件

# host-gateway 其实是个特殊的 CDN,在运行时会被替换为真实的宿主网关 IP 地址 # 通过查看 `cat /etc/hosts` 即可得知已经被替换成 docker0 的网管 IP 地址 # 创建容器的时候添加 `--add-host=host.docker.internal:host-gateway` # 需要注意的是: # 对于 mac 上的 docker 设置还有略微不一样 # mac docker 版本在 v17.12-v18.02 需要将 host.docker.internal 替换成 docker.for.mac.host.internal  # mac docker 版本在 v17.06-v18.11 需要替换成 docker.for.mac.localhost docker run -it --add-host=host.docker.internal:host-gateway {image} sh  # 进入容器中,可以通过 ping 进行测试: ping host.docker.internal  # 比如在容器中连接宿主机中的 mysql 时,那么则需要设置为 host.docker.internal:3306

第三种:参考

Docker:WARNING: Published ports are discarded when using host network mode 解决方法-CSDN博客

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!