我有两个网络接口eth0
和eth1
,
如何将所有的docker容器绑定到eth1
,并让所有的网络流量通过eth1
进出
谢谢~
更新
我尝试用133绑定到eth1
。130.60.36.
但是我还是没有运气,我仍然得到了eth0 IP作为容器中的公共IP。网络流量不通过eth 1流出
➜ ~ docker run -d --name Peach_1 -p 133.130.60.36::9998 -ti sample/ubuntu-vnc-selenium-firefox
➜ ~ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
eb28f0d1c337 sample/ubuntu-vnc-selenium-firefox "/opt/bin/run_sele_s 4 minutes ago Up 4 minutes 5901/tcp, 133.130.60.36:32768->9998/tcp Peach_1
➜ ~ docker exec -ti Peach_1 zsh
➜ / curl ipecho.net/plain ; echo
133.130.101.114
3条答案
按热度按时间r8uurelv1#
这是docker docs的一些东西
https://docs.docker.com/v17.09/engine/userguide/networking/default_network/binding/
如果您希望限制更严格,并且只允许通过主机上的特定外部接口联系容器服务,则有两种选择。当你调用docker run时,你可以使用
-p IP:host_port:container_port
或-p IP::port
来指定一个特定绑定的外部接口。或者,如果您总是希望Docker端口转发绑定到一个特定的IP地址,您可以编辑系统范围的Docker服务器设置并添加选项--ip=IP_ADDRESS
。请记住在编辑此设置后重新启动Docker服务器。vuktfyat2#
将IP放入
-p
只对到达服务器的流量有效,对于离开服务器的流量,您可以为每个容器分配静态本地IP,然后在iptables
或snat
中更改源IP。以下是iptables规则的示例:vq8itlhq3#
我已经读完了整篇文章,但我还是迷路了。这似乎是最可靠的职位,但在我的情况下,让我们说:
设置:
当我在主机上触发
curl https://ifconfig.me/
时,我将接收eth0
的IP我想达到的目标
我想要一个静态IP
172.20.0.100
的容器,通过eth1
接口触发curl请求。我所尝试的
我添加了以下内容:
但在跑步时:
这会导致超时。
令人惊讶的是,当我将
eth1
IP与eth0
IP交换时,如下所示结果与预期一致,因此我收到了
eth0
的IP你能告诉我我错过了什么吗?