问题描述:在k8s集群中主机无法ping通service ip,但是pod ip是可以ping通
1.先看下serviceIP是怎么来的?
serviceIP是serviceController生成的,参数–service-cluster-ip-range string会配置在controller-manager上,serviceController会在这个参数指定的cidr范围内取一个IP
data:image/s3,"s3://crabby-images/7dc3a/7dc3a42837e9e8201748b2ae2405652bb7b76a7e" alt=""
2.为什么不能ping?
serviceIP是虚拟的地址,没有分配给任何网络接口,当数据包传输时不会把这个IP作为数据包的源IP或目的IP。
kube-proxy在iptables模式下,这个IP没有被设置在任何的网络设备上,ping这个IP的时候,没有任何的网络协议栈会回应这个ping请求。
可以查看kube-proxy的服务的配置文件,核查kube-proxy的代理模式。mode处不配置,默认为iptables模式
data:image/s3,"s3://crabby-images/2661a/2661a49355057b8acbd52b9cfad75960be2b3147" alt=""
data:image/s3,"s3://crabby-images/218b3/218b3b61291473e0335d74740f56f8e86937dd93" alt=""
kubectl edit configmap -n kube-system kube-proxy
data:image/s3,"s3://crabby-images/fd2d6/fd2d6b049218abd67fa89ba995e1e41e8f48cd3f" alt=""
在iptables模式时,clusterIp会在iptables的PREROUTING链里面用于nat转换规则中。
而在ipvs模式下,会使用在ipvs模块的ipvs规则转换中。
在ipvs模式下,所有的clusterIp会被设置在node上的kube-ipvs0的虚拟网卡上,这个时候去ping是可以通的。
data:image/s3,"s3://crabby-images/3a345/3a345129a8b781079118b0f2a801a949f5c7d91e" alt=""
data:image/s3,"s3://crabby-images/fb013/fb013457edd19241f7e2c3bd0b16fee3ba2a780d" alt=""
data:image/s3,"s3://crabby-images/6c2e7/6c2e72e5d0952592fc6cef745eeebed555f27728" alt=""
完美解决
网友评论