宿主机访问虚拟机内的Docker静态IP
Docker容器之内网独立IP访问
背景
搭了一个Consul集群,在Homestead用Docker搭建后,想在物理机可以直接访问ip:8500 直接访问Consul的Web页面。下面记录下我自己的解决过程
环境
Win10 + Hyper-V + Vagrant
实现目标
宿主机访问虚拟机内的Docker独立IP
IP关系图解
在虚拟机中创建一个自定义网络
docker network create --subnet=172.18.0.0/24 docker-br0
# 创建一个172.18.0.0网段,网桥的名字命名为docker-br0,这两个根据自己需要来
查看容器的ip地址
我们在虚拟机环境下,使用ping
访问172.18.0.2
测试是否能通
到物理机win10中访问172.18.0.2
,测试是否能访问
虚拟机开启路由转发
echo "net.ipv4.ip_forward=1" >> /etc/sysctl.conf
# sysctl -p 检查是否设置成功
# 设置成功后vagrant需要重启,后续才能ping通
物理机win10路由表加入172.18.0.0
route add 172.18.0.0 mask 255.255.255.0 192.168.137.200
物理机win10再次访问172.18.0.2
注* Consul实际在物理机Windows可以直接用Docker搭建,个人喜好问题。
- 最后总结
1.创建自定义网段
2.选一个自定义网段内的IP,开启容器
3.开启虚拟机的路由转发
4.在物理机路由中添加自定义网段的路由条目,指定接口为虚拟机的IP地址 - 参考资料
consul集群
物理机与虚拟机docker通信
hyper-v网卡设置
本作品采用《CC 协议》,转载必须注明作者和本文链接