參考:https://kubernetes.io/zh/docs/tasks/network/customize-hosts-file-for-pods/
當 DNS 配置以及其它選項不合理的時候,通過向 Pod 的 /etc/hosts 文件中添加條目, 可以在 Pod 級別覆蓋對主機名的解析。你可以通過 PodSpec 的 HostAliases 字段來添加這些自定義條目。
建議通過使用 HostAliases 來進行修改,因為該文件由 Kubelet 管理,並且 可以在 Pod 創建/重啟過程中被重寫。
默認 hosts 文件內容
# Kubernetes-managed hosts file.
127.0.0.1 localhost
::1 localhost ip6-localhost ip6-loopback
fe00::0 ip6-localnet
fe00::0 ip6-mcastprefix
fe00::1 ip6-allnodes
fe00::2 ip6-allrouters
10.200.0.4 nginx
默認情況下,hosts 文件只包含 IPv4 和 IPv6 的樣板內容,像 localhost 和主機名稱。
通過 HostAliases 增加額外條目
除了默認的樣板內容,我們可以向 hosts 文件添加額外的條目。 例如,要將 foo.local、bar.local 解析為 127.0.0.1, 將 foo.remote、 bar.remote 解析為 10.1.2.3,我們可以在 .spec.hostAliases 下為 Pod 配置 HostAliases。
apiVersion: v1
kind: Pod
metadata:
name: hostaliases-pod
spec:
restartPolicy: Never
hostAliases:
- ip: "127.0.0.1"
hostnames:
- "foo.local"
- "bar.local"
- ip: "10.1.2.3"
hostnames:
- "foo.remote"
- "bar.remote"
containers:
- name: cat-hosts
image: busybox
command:
- cat
args:
- "/etc/hosts"
hosts 文件的內容看起來類似如下這樣:
# Kubernetes-managed hosts file.
127.0.0.1 localhost
::1 localhost ip6-localhost ip6-loopback
fe00::0 ip6-localnet
fe00::0 ip6-mcastprefix
fe00::1 ip6-allnodes
fe00::2 ip6-allrouters
10.200.0.5 hostaliases-pod
# Entries added by HostAliases.
127.0.0.1 foo.local bar.local
10.1.2.3 foo.remote bar.remote
在最下面額外添加了一些條目。
為什么 kubelet 管理 hosts 文件?
kubelet 管理 Pod 中每個容器的 hosts 文件,避免 Docker 在容器已經啟動之后去 修改 該文件。
注意:
請避免手工更改容器內的 hosts 文件內容。
如果你對 hosts 文件做了手工修改,這些修改都會在容器退出時丟失。