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地址。
分类:
docker
标签:
docker容器的网络内到外
, docker容器的网络
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具
· Manus的开源复刻OpenManus初探