play with docker multi-host networking

本文介绍了如何通过ovstunnel实现Docker容器跨主机通信。具体步骤包括在两台主机上搭建Docker环境、创建容器并配置ovs-switch及GRE隧道以确保不同主机间的容器能够互相通信。

使用ovs tunnel组建docker multi-host netwrork记录

分别在两台机器上安装docker,分别为node1, node2

在node1 上创建两个container

docker run --net=mybr  --name=c1 -d -ti busybox sh

docker run --net=mybr  --name=c2 -d -ti busybox sh

在node2上创建一个container:

docker run --net=mybr  --name=c1 -d -ti busybox sh

因为默认情况下docker分配的地址都是从172.17.0.2开始,需要将node1上的c1关闭,

这样避免了地址冲突

docker stop c1


在node1,node2上创建ovs-switch以及gre接口:

ubuntu@docker-node2:~$ ovs-vsctl add-br br-int
ubuntu@docker-node2:~$ sudo ip link add veth0 type veth peer name veth1
ubuntu@docker-node2:~$ sudo ovs-vsctl add-port br-int veth1
ubuntu@docker-node2:~$ sudo brctl addif docker0 veth0
ubuntu@docker-node2:~$ sudo ip link set veth1 up
ubuntu@docker-node2:~$ sudo ip link set veth0 up
在node1上添加gre接口,node1, node2 ip分别为192.168.8.81, 192.168.8.82
ovs-vsctl add-port br-int gre0 -- \
set interface gre0 type=gre options:remote_ip=192.168.8.82
在node2上配置gre:
ovs-vsctl add-port br-int gre0 -- \
set interface gre0 type=gre options:remote_ip=192.168.8.81

验证联通性:
docker exec -ti sh
/ # ping 172.17.0.3
PING 172.17.0.3 (172.17.0.3): 56 data bytes
64 bytes from 172.17.0.3: seq=0 ttl=64 time=1.009 ms
^C
--- 172.17.0.3 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 1.009/1.009/1.009 ms
在node1上抓包:
root@docker-node1:~# tcpdump -n -i eth0 proto gre
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on eth0, link-type EN10MB (Ethernet), capture size 262144 bytes
14:34:21.514041 IP 192.168.8.82 > 192.168.8.81: GREv0, length 102: IP 172.17.0.2 > 172.17.0.3: ICMP echo request, id 3072, seq 0, length 64
14:34:21.515404 IP 192.168.8.81 > 192.168.8.82: GREv0, length 102: IP 172.17.0.3 > 172.17.0.2: ICMP echo reply, id 3072, seq 0, length 64
14:34:22.513888 IP 192.168.8.82 > 192.168.8.81: GREv0, length 102: IP 172.17.0.2 > 172.17.0.3: ICMP echo request, id 3072, seq 1, length 64
14:34:22.514560 IP 192.168.8.81 > 192.168.8.82: GREv0, length 102: IP 172.17.0.3 > 172.17.0.2: ICMP echo reply, id 3072, seq 1, length 64
14:34:23.513956 IP 192.168.8.82 > 192.168.8.81: GREv0, length 102: IP 172.17.0.2 > 172.17.0.3: ICMP echo request, id 3072, seq 2, length 64
14:34:23.514577 IP 192.168.8.81 > 192.168.8.82: GREv0, length 102: IP 172.17.0.3 > 172.17.0.2: ICMP echo reply, id 3072, seq 2, length 64

参考

http://docker-k8s-lab.readthedocs.io/en/latest/index.html

http://chunqi.li/

<think>好的,用户遇到了Docker运行时使用--add-host参数导致的无效IP地址错误,具体是执行docker run时--add-host host.docker.internal:host-gateway报错。我需要帮他解决这个问题。 首先,我应该回忆一下Docker--add-host的用法。这个参数的作用是向容器的/etc/hosts文件添加条目,格式应该是<hostname>:<IP>。而用户写的是host.docker.internal:host-gateway,这显然不符合IP的格式,因为host-gateway是一个特殊标识,可能在docker run命令中不被直接支持,但在docker-compose中可以使用extra_hosts配置。 根据引用[2]中的信息,在docker-compose.yml中可以通过extra_hosts来设置host.docker.internal,使用host-gateway作为值。这可能意味着在docker run命令中直接使用host-gateway作为IP地址是不被接受的,导致无效IP错误。 那么,解决方法可能分为两种情况:使用docker-compose或者必须使用docker run的情况。 对于使用docker-compose的情况,用户应该修改docker-compose.yml,添加extra_hosts配置,如引用[2]中的示例。这样Docker会正确解析host-gateway为宿主机的IP。 如果用户必须使用docker run命令,可能需要手动获取宿主机的IP地址,然后替换host-gateway为实际的IP。例如,在Linux中,可以使用ip route或hostname -I命令获取宿主机IP,然后在--add-host参数中使用这个IP。 另外,用户的环境可能是Ubuntu的Docker,而之前的问题可能与系统环境有关,如引用[3]提到环境差异导致的问题。需要确认宿主机系统,以及Docker版本是否支持host.docker.internal的解析。较新的Docker版本可能支持host.docker.internal自动映射,但可能需要开启某些功能。 总结可能的解决方案步骤:检查Docker版本是否支持host-gateway;使用docker-compose配置;或者手动指定宿主机IP。同时提醒用户注意不同系统的差异,比如Linux和macOS/Windows的区别,因为host.docker.internal在macOS和Windows上可能默认支持,但在Linux需要额外配置。</think>### 解决Docker运行时因`--add-host`参数导致的无效IP地址错误 #### 问题分析 当使用`docker run`命令添加`--add-host host.docker.internal:host-gateway`时,会报错`invalid IP address`。这是因为`--add-host`参数要求格式为`<hostname>:<IP地址>`,而`host-gateway`是Docker Compose特有的语法糖,无法直接在`docker run`中使用[^2]。 --- #### 解决方法 ##### 方法1:使用Docker Compose配置 1. 创建或修改`docker-compose.yml`文件,添加`extra_hosts`字段: ```yaml version: '3.7' services: your_service: image: your_image extra_hosts: - "host.docker.internal:host-gateway" ``` 2. 运行`docker-compose up`启动容器。Docker会自动将`host.docker.internal`解析为宿主机的IP。 --- ##### 方法2:手动指定宿主机IP(适用于`docker run`) 1. **获取宿主机IP**: - **Linux/macOS**:执行`ip route show default | awk '/default/ {print $3}'`获取网关IP(通常为宿主机IP)。 - **Windows(WSL)**:执行`cat /etc/resolv.conf | grep nameserver | awk '{print $2}'`。 2. 替换`host-gateway`为实际IP: ```bash docker run --add-host host.docker.internal:<宿主机IP> your_image ``` --- ##### 方法3:启用Docker的`host.docker.internal`支持(Linux专用) 对于Linux系统,需在`/etc/docker/daemon.json`中添加配置: ```json { "features": { "buildkit": true }, "experimental": true, "hosts": ["unix:///var/run/docker.sock"] } ``` 重启Docker服务后,部分新版本Docker可直接使用`host.docker.internal`[^3]。 --- #### 注意事项 1. 不同操作系统(如Ubuntu与CentOS)的路径和命令可能差异较大,需根据实际环境调整。 2. 若使用Docker Desktop(macOS/Windows),`host.docker.internal`默认已支持,无需额外配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值