news 2026/4/18 12:24:57

K8S-daemonset控制器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
K8S-daemonset控制器

一、 DaemonSet 概述
DaemonSet 控制器能够确保 k8s 集群所有的节点都运行一个相同的 pod 副本,当向 k8s 集群中增加 node 节点时,这个 node 节点也会自动创建一个 pod 副本,当 node 节点从 集群移除,这些 pod 也会自动删除;删除 Daemonset 也会删除它们创建的 pod

DaemonSet 工作原理

daemonset 的控制器会监听 kuberntes 的 daemonset 对象、pod 对象、node 对象,这些被监听的对象之变动,就会触发 syncLoop 循环让 kubernetes 集群朝着 daemonset 对象描述的状态进行演进。

Daemonset 典型的应用场景

在集群的每个节点上运行存储,比如:glusterd 或 ceph。 在每个节点上运行日志收集组件,比如:flunentd 、 logstash、filebeat 等。 在每个节点上运行监控组件,比如:Prometheus、 Node Exporter 、collectd 等。

DaemonSet 与 Deployment 的区别

Deployment 部署的副本 Pod 会分布在各个 Node 上,每个 Node 都可能运行好几个副本。

DaemonSet 的不同之处在于:每个 Node 上最多只能运行一个副本。

二、DaemonSet 资源清单文件编写技巧

[root@k8s-master01 ~]# kubectl explain ds
  • 字段作用
    apiVersion当前资源使用的 api 版本,跟 VERSION: apps/v1 保持 一致
    kind资源类型,跟 KIND: DaemonSet 保持一致
    metadata元数据,定义 DaemonSet 名字的
    spec定义容器的
    status状态信息,不能改
[root@k8s-master01 ~]# kubectl explain ds.spec

[root@k8s-master01 ~]# kubectl explain ds.spec.template

清单模版

apiVersion: apps/v1 kind: DaemonSet metadata: name: pod-controller # 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

三、DaemonSet 使用案例

[root@k8s-master01 ~]# cat pod-controller.yaml apiVersion: apps/v1 kind: DaemonSet metadata: name: pod-controller 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-master01 ~]# kubectl apply -f pod-controller.yaml daemonset.apps/pod-controller created
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:01:36

ansible的概念及基本操作(一)

文章目录前言一、Ansible 概述和原理1.1 ansible概念1.2 ansible原理二、ansible基本操作2.1 环境配置2.2 command模块基本操作2.3 shell 模块2.4 cron 模块2.5 user 模块2.6 group 模块2.7 copy 模块2.9 hostname 模块2.10 ping 模块总结前言 本文讲述了ansible的基本原理与概…

作者头像 李华
网站建设 2026/4/18 8:42:23

Linux内核信号队列深度剖析:从sigqueue到实时信号处理核心技术

Linux内核信号队列深度剖析:从sigqueue到实时信号处理核心技术 【免费下载链接】linux-insides-zh Linux 内核揭秘 项目地址: https://gitcode.com/gh_mirrors/li/linux-insides-zh 在Linux内核的进程间通信机制中,信号处理系统扮演着至关重要的角…

作者头像 李华
网站建设 2026/4/18 8:15:55

超细整理,性能测试如何做?怎么做?常见面试题(汇总七)

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 1、保险项目-性能…

作者头像 李华
网站建设 2026/4/18 3:39:56

SpringBoot配置文件

前面我们一直使用springboot项目创建完毕后自带的application.properties进行属性的配置,而如果在项目中,我们需要配置大量的属性,采用properties配置文件这种 keyvalue 的配置形式,就会显得配置文件的层级结构不清晰,…

作者头像 李华
网站建设 2026/4/18 9:41:31

从零开始:Paddle-Lite让Android AI模型部署变得简单

还在为在Android设备上部署AI模型而头疼吗?编译错误、内存不足、运行缓慢这些问题困扰着无数开发者。今天,我们将通过Paddle-Lite这个强大的工具,彻底告别复杂的部署流程。作为飞桨推出的高性能深度学习端侧推理引擎,Paddle-Lite专…

作者头像 李华
网站建设 2026/4/17 13:20:43

draft-js自定义工具栏开发实战:从零打造专属编辑体验

draft-js自定义工具栏开发实战:从零打造专属编辑体验 【免费下载链接】draft-js A React framework for building text editors. 项目地址: https://gitcode.com/gh_mirrors/dra/draft-js 还在为编辑器工具栏样式单调、功能固化而头疼吗?每次看到…

作者头像 李华