kubernetes中Pod网络的创建原理

本文介绍了Kubernetes Pod的网络原理,强调Pod作为一个逻辑概念,通过pause容器创建网络命名空间,使得Pod内的容器共享网络。Pod与主机的连接通过veth对和网络插件如flannel或calico实现通信。探讨了不同网络插件的工作方式,帮助理解Pod在集群中的网络行为。

Pod的概念

Pod是kubernetes中最重要的概念,无论是deployment、daemonSet还是job等等各种容器编排方式,都是围绕着pod进行的。

其实pod从根本上讲只是一个逻辑概念,和其他的资源对象一样,pod只是k8s中声明式定义的一个yaml文件。最终由调度到的k8s节点上的kubelet服务调用linux操作系统namespace、cgroup、docker等等底层原理来实现。

Pod共享网络

我们每创建一个pod,k8s都会首先创建一个pause容器,这个pause容器非常小,只有100多kB,是一个汇编语言实现的容器,和名字一样,它永远处于暂停状态。

4b0a583ca9101fb01f481ecacb9d2fe9.png

这个容器的作用就是给这个pod创建network namespace,之后这个pod中的其他容器都通过join namespace的方式加入到pod的network namespace中。

我们通在nginx的pod的namespace中新增一个busybox容器,模拟一下业务容器join到pause容器的network namespace的现象。

docker run -itd --name=test --network=container:k8s_POD_nginx-85b98978db-jnpp8_default_b0bd5a02-454c-4049-b7d3-166ef3618c9d_0  busybox

718c9e92f9bef15d96db42dfa367bc5e.png

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值