先来通过下图来表达一下现象:
K8s hosts 解析 HostAliases_docker
通过图片内容可以看出,在 k8s 中,容器内部的 hosts 解析是不会继承宿主机的 host 解析的(与宿主机不相干),常规情况我们在这个应用体系内都有公共的 DNS 服务,DNS 服务是跨主机和容器共享的。

只是有时候在没有公共DNS解析服务的情况下,而容器中的程序又需要通过本地域名的方式去请求接口。这就需要我们手工配置 hosts 映射,这个配置如图来看在宿主机上配置是不可行的,那么在 k8s 的应用场景中,它为我们提供了可以为 pod 配置 hosts 解析的方式,如题所述就是使用 HostAliases

使用说明

基于Pod 的示例:

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"

基于 Deployment 的示例:

apiVersion: v1
kind: Deployment
metadata:
  name: hostaliases-dp
  namespace: default
spec:
  replicas: 1
  selector:
    name: hostaliases-pod
  template:
    metadata:
      labels:
        name: hostaliases-pod
    spec:
	  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
        imagePullPolicy: Always
	    command:
	    - cat
	    args:
	    - "/etc/hosts"

以上内容,只关注 hostAliases 片段即可,使用 hostAliases 配置时没有相关其他配置的要求。

官网资料:https://kubernetes.io/zh/docs/tasks/network/customize-hosts-file-for-pods/


(END)