一、认识DaemonSet控制器
DaemonSet是Pod控制器的又一种实现,用于在集群中的全部节点上同时运行一份指定的Pod资源副本,后续加入集群的工作节点也会自动创建一个相关的Pod对象,当从集群移除节点时,此类Pod对象也将被自动回收而无需重建。管理员也可以使用节点选择器及节点标签指定仅在部分具有特定特征的节点上运行指定的Pod对象。
DaemonSet控制器是一种特殊的控制器,它有特定的应用场景,通常运行那些执行系统级操作任务的应用,其应用场景具体如下:
1)运行集群存储的守护进程,如在各个节点上运行glusterd或ceph
2)在各个节点上运行日志收集守护进程,如fluentd和logstash
3)在各个节点上运行监控系统的代理守护进程,如Prometheus Node Exporter、Collectd、Datadog agent等
二、DaemonSet控制器实验
1)编写DaemonSet控制器的yaml文件
]# cat daemonset.yaml
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: filebeat-ds
labels:
app: filebeat
spec:
selector:
matchLabels:
app: filebeat
template:
metadata:
labels:
app: filebeat
spec:
containers:
- name: filebeat
image: ikubernetes/filebeat:5.6.5-alpine
imagePullPolicy: IfNotPresent
lifecycle:
postStart:
exec:
command: ["/bin/sh","-c"," echo hello filebeat > /tmp/filebeat.txt"]
env:
- name: LOG_LEVEL
value: info
- name: REDIS_HOST
value: node1:6379
]# kubectl apply -f daemonset.yaml
daemonset.apps/filebeat-ds created
2)查看Pod信息
]# kubectl get pods -o wide --show-labels
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES LABELS
filebeat-ds-9htfd 1/1 Running 0 86s 10.244.1.48 node1 <none> <none> app=filebeat,controller-revision-hash=6d454c8f79,pod-template-generation=1
filebeat-ds-jtt7z 1/1 Running 0 86s 10.244.0.18 master <none> <none> app=filebeat,controller-revision-hash=6d454c8f79,pod-template-generation=1
filebeat-ds-vnnz8 1/1 Running 0 86s 10.244.2.17 node2 <none> <none> app=filebeat,controller-revision-hash=6d454c8f79,pod-template-generation=1
可以看到集群中每一个上都运行了一个DaemonSet控制器的Pod副本
3)进入Pod内部查看
]# kubectl exec filebeat-ds-9htfd -it -- /bin/sh
/ # cat /tmp/filebeat.txt
hello filebeat
/ # printenv | grep -Ei "log_level|redis_host"
LOG_LEVEL=info
REDIS_HOST=node1:6379
/ # exit
设定的环境变量信息的确存在
4)查看DaemonSet控制器的详细信息
]# kubectl get ds -o wide
NAME DESIRED CURRENT READY