daemonset控制器
1. DaemonSet 概述
DaemonSet 控制器能够确保 k8s 集群所有的节点都运行一个相同的 pod 副本,当向
k8s 集群中增加 node 节点时,这个 node 节点也会自动创建一个 pod 副本,当 node 节点从
集群移除,这些 pod 也会自动删除;删除 Daemonset 也会删除它们创建的 pod
2. DaemonSet 工作原理:如何管理 Pod
daemonset 的控制器会监听 kuberntes 的 daemonset 对象、pod 对象、node 对象,这
些被监听的对象之变动,就会触发 syncLoop 循环让 kubernetes 集群朝着 daemonset 对象
描述的状态进行演进。
3. Daemonset 典型的应用场景
在集群的每个节点上运行存储,比如:glusterd 或 ceph。
在每个节点上运行日志收集组件,比如:flunentd 、 logstash、filebeat 等。
在每个节点上运行监控组件,比如:Prometheus、 Node Exporter 、collectd 等。
4. DaemonSet 与 Deployment 的区别
Deployment 部署的副本 Pod 会分布在各个 Node 上,每个 Node 都可能运行好几
个副本。
DaemonSet 的不同之处在于:每个 Node 上最多只能运行一个副本。
5. daemon yaml编写实例
[root@master1 daemonset]# cat > /root/daemonset/daemonset.yaml <<END
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: fluentd-elasticsearch
labels:
k8s-app: fluentd-logging
namespace: kube-system
spec:
selector:
matchLabels:
name: fluentd-elasticsearch
template:
metadata:
labels:
name: fluentd-elasticsearch
spec:
tolerations:
- key: node-role.kubernetes.io/master
effect: NoSchedule
containers:
- image: xianchao/fluentd:v2.5.1 #images需要先在各个节点上pull下来
imagePullPolicy: IfNotPresent
name: fluentd-elasticsearch
resources:
requests:
memory: "1Gi"
cpu: "100m"
limits:
memory: "1Gi"
cpu: "200m"
volumeMounts:
- name: varlog
mountPath: /var/log
- name: varlibdockercontainers
mountPath: /var/lib/docker/containers
volumes:
- name: varlog
hostPath:
path: /var/log
- name: varlibdockercontainers
hostPath:
path: /var/lib/docker/containers
END
kubectl apply -f daemonset.yaml
kubectl get ds -n kube-system
kubectl get pods -n kube-system -l name=fluentd-elasticsearch -o wide