k8s中pod使用hostNetwork导致定义的service无法访问

在k8s中,若pod使用主机网络,也就是hostNetwork=true。则该pod会使用主机的dns以及所有网络配置,无法使用k8s自带的dns解析服务,也就意味着无法访问service中定义的服务。除非修改主机上的域名解析,也就是修改/etc/resolv.conf文件,使主机可以用k8s自身的dns服务。

例:

当前k8s中存在两个pod,一个使用主机网络部署podA,一个正常部署的podB。若定义了一个名为subscribe数据库的servcie,则此刻podA无法使用subscribe作为域名进行解析并使用;podB可以使用mysql进行正常访问。除非podA所在的宿主机修改/etc/resolv.conf,将k8s的dns添加进来。

k8s中pod使用hostNetwork导致定义的service无法访问