docker容器的通讯——内部访问外部


《容器访问外部世界:》

 

原理:NAT地址转换

 

 

 

1.物理机可以连接外网

2.docker run -it busybox

ip a

容器可以访问外网

3.查看iptables策略,了解策略原理

iptables -t nat -s

 

-A POSTROUTING -s 172.17.0.0/16 ! -o docker0 -j MASQUERADE

收到来自这个网段的包,把它交给MASQUERADE,然后它将包的源地址替换成host主机的地址发送出去,就是做了一次网络源地址转换(NAT)

 

4.开启一个终端运行,监控docker0网卡:

tcpdump -i docker0 -n icmp

 

5.在另一个终端:

进容器ping百度

docker run -it busybox

ping www.baidu.com

结果,发现容器的IP地址交给了MASQUERADE处理

 

 

 

6.结束上一个终端,运行监控物理机网卡

tcpdump -i ens33 -n icmp

发现已经将容器的地址进行转换了,成了物理机的IP地址。

 

 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM