构建一个基本的 DaemonSet

本页演示如何构建一个基本的 DaemonSet, 用其在 Kubernetes 集群中的每个节点上运行 Pod。 这个简单的使用场景包含了从主机挂载一个文件,使用 Init 容器记录文件的内容, 以及使用 pause 容器。

准备开始

你必须拥有一个 Kubernetes 的集群,且必须配置 kubectl 命令行工具让其与你的集群通信。 建议运行本教程的集群至少有两个节点,且这两个节点不能作为控制平面主机。 如果你还没有集群,你可以通过 Minikube 构建一个你自己的集群,或者你可以使用下面的 Kubernetes 练习环境之一:

为了演示 DaemonSet 的行为,Kubernetes 集群至少需包含两个节点(一个控制平面节点和一个工作节点)。

定义 DaemonSet

在此任务中,将创建一个基本的 DaemonSet,确保 Pod 的副本被调度到每个节点上。 此 Pod 将使用 Init 容器从主机读取并记录 /etc/machine-id 的内容, 而主容器将是一个 pause 容器,用于保持 Pod 运行。

  1. application/basic-daemonset.yaml
  1. apiVersion: apps/v1
  2. kind: DaemonSet
  3. metadata:
  4. name: example-daemonset
  5. spec:
  6. selector:
  7. matchLabels:
  8. app.kubernetes.io/name: example
  9. template:
  10. metadata:
  11. labels:
  12. app.kubernetes.io/name: example
  13. spec:
  14. containers:
  15. - name: pause
  16. image: registry.k8s.io/pause
  17. initContainers:
  18. - name: log-machine-id
  19. image: busybox:1.37
  20. command: ['sh', '-c', 'cat /etc/machine-id > /var/log/machine-id.log']
  21. volumeMounts:
  22. - name: machine-id
  23. mountPath: /etc/machine-id
  24. readOnly: true
  25. - name: log-dir
  26. mountPath: /var/log
  27. volumes:
  28. - name: machine-id
  29. hostPath:
  30. path: /etc/machine-id
  31. type: File
  32. - name: log-dir
  33. hostPath:
  34. path: /var/log
  1. 基于(YAML)清单创建 DaemonSet:

    1. kubectl apply -f https://k8s.io/examples/application/basic-daemonset.yaml
  2. 完成创建操作后,你可以验证 DaemonSet 是否在集群中的每个节点上运行 Pod:

    1. kubectl get pods -o wide

    输出将列出每个节点上有一个 Pod,类似于:

    1. NAME READY STATUS RESTARTS AGE IP NODE
    2. example-daemonset-xxxxx 1/1 Running 0 5m x.x.x.x node-1
    3. example-daemonset-yyyyy 1/1 Running 0 5m x.x.x.x node-2
  3. 你可以通过检查从主机挂载的日志目录来查看 /etc/machine-id 文件的日志内容:

    1. kubectl exec <pod-name> -- cat /var/log/machine-id.log

    其中 <pod-name> 是某一个 Pod 的名称。

清理现场

  1. kubectl delete --cascade=foreground --ignore-not-found --now daemonsets/example-daemonset

这个简单的 DaemonSet 例子介绍了 Init 容器和主机路径卷这类关键组件, 你可以在此基础上扩展以应对更高级的使用场景。有关细节参阅 DaemonSet