一. DaemonSet 解释
- 使用Deployment部署时,部署的服务会随机安装到k8s的多个节点上,可能会出现一次部署的多个pod安装到k8s的同一个节点的情况,
- 使用 DaemonSet无需指定副本数量,默认除master外会给每个机器都部署一个,k8s中有几个work节点,就会部署几个副本,防止多个程序安装到同一个节点的问题DaemonSet简称DS
- DaemonSet的yaml与Deployment的除了kind不同以外,其它大致相同
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: ds-test
namespace: default
labels:
app: ds-test
spec:
selector:
matchLabels:
app: ds-test
template:
metadata:
labels:
app: ds-test
spec:
containers:
- name: ds-test
image: nginx
- DaemonSet 控制器确保所有(或一部分)的节点都运行了一个指定的 Pod 副本。
- 每当向集群中添加一个节点时,指定的 Pod 副本也将添加到该节点上
- 当节点从集群中移除时,Pod 也就被垃圾回收了
- 删除一个 DaemonSet 可以清理所有由其创建的 Pod
- DaemonSet 的典型使用场景有:
- 在每个节点上运行集群的存储守护进程,例如 glusterd、ceph
- 在每个节点上运行日志收集守护进程,例如 fluentd、logstash
- 在每个节点上运行监控守护进程,例如 Prometheus Node Exporter、Sysdig Agent、collectd、Dynatrace OneAgent、APPDynamics Agent、Datadog agent、New Relic agent、Ganglia gmond、Instana Agent 等