Kubernetes学习之DaemonSet控制器

本文介绍了DaemonSet控制器,它是Kubernetes中确保每个节点上运行一个Pod副本的工具,常用于系统级任务,如存储守护进程、日志收集和监控代理。文章通过实例展示了如何创建和管理DaemonSet,包括更新策略的两种方式:滚动更新和删除时更新,并提及了滚动更新的控制选项和回滚机制。
摘要由CSDN通过智能技术生成

一、认识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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值