DaemonSet类型的控制器可以保证集群中的每一台(或指定)节点上都运行一个且只有一个副本,一般适用于日志收集、节点监控等场景
DaemonSet控制器的特点:
DaemonSet的资源清单模板
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: pod-controller # ds名称
namespace: dev # ds所属的命名空间
labels: # 给ds打标签
controller: daemonset
spec:
revisionHistoryLimit: 3 # 保留历史版本数量,默认为10
updateStrategy: # Pod更新策略,默认是RollingUpdate
type: RollingUpdate # 滚动更新策略。另一种是OnDelete,其没有子属性配置参数
rollingUpdate: # 当type为RollingUpdate的时候生效,为其配置参数
maxSurge: 25% # 升级过程中可以超过期望的Pod的最大数量,可以为百分比,也可以为整数。默认是25%
maxUnavailable: 25% # 升级过程中最大不可用状态的Pod数量,可以为百分比,也可以为整数。默认是25%
selector: # 选择器,通过该控制器管理哪些pod
matchLabels: # Labels匹配规则。和matchExpressions类似
app: nginx-pod
matchExpressions: # Expressions匹配规则。和matchLabels类似
- {key: app, operator: In, values: ["nginx-pod"]}
template: # pod副本创建模板。属性和Pod的属性一样
metadata:
labels:
app: nginx-pod
spec:
containers:
- name: nginx
image: nginx:latest
ports:
- name: nginx-port
containerPort: 80
protocol: TCP
新建pod-controller.yaml,内容如下。并运行DaemonSet
[root@k8s-master ~]# cat pod-controller.yaml
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: pod-controller
namespace: dev
labels:
controller: daemonset
spec:
selector:
matchLabels:
app: nginx-pod
template:
metadata:
labels:
app: nginx-pod
spec:
containers:
- name: nginx
image: nginx:latest
ports:
- name: nginx-port
containerPort: 80
protocol: TCP
[root@k8s-master ~]#
[root@k8s-master ~]# kubectl apply -f pod-controller.yaml
daemonset.apps/pod-controller created
[root@k8s-master ~]#
[root@k8s-master ~]# kubectl get ds -n dev -o wide
NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE CONTAINERS IMAGES SELECTOR
pod-controller 2 2 2 2 2 61s nginx nginx:latest app=nginx-pod
[root@k8s-master ~]#
[root@k8s-master ~]# kubectl delete ds pod-controller -n dev
daemonset.apps "pod-controller" deleted
[root@k8s-master ~]#