十五. Kubernetes 工作负载 之 DaemonSet

DaemonSet是Kubernetes的一种控制器,用于确保所有(或特定)节点上都运行一个特定的Pod副本。它常用于运行如存储守护进程、日志收集和监控服务等需要在每个节点上存在的应用。当节点加入或离开集群时,DaemonSet会自动管理和调整Pod的分布。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一. DaemonSet 解释

  1. 使用Deployment部署时,部署的服务会随机安装到k8s的多个节点上,可能会出现一次部署的多个pod安装到k8s的同一个节点的情况,
  2. 使用 DaemonSet无需指定副本数量,默认除master外会给每个机器都部署一个,k8s中有几个work节点,就会部署几个副本,防止多个程序安装到同一个节点的问题DaemonSet简称DS
  3. DaemonSet的yaml与Deployment的除了kind不同以外,其它大致相同
apiVersion: apps/v1
kind: DaemonSet
metadata:
  name: ds-test
  namespace: default
  labels:
    app: ds-test
spec:
  selector:
    matchLabels:
      app: ds-test
  template:
    metadata:
      labels:
        app: ds-test
    spec:
      containers:
      - name: ds-test
        image: nginx
  1. DaemonSet 控制器确保所有(或一部分)的节点都运行了一个指定的 Pod 副本。
  1. 每当向集群中添加一个节点时,指定的 Pod 副本也将添加到该节点上
  2. 当节点从集群中移除时,Pod 也就被垃圾回收了
  3. 删除一个 DaemonSet 可以清理所有由其创建的 Pod
  1. DaemonSet 的典型使用场景有:
  1. 在每个节点上运行集群的存储守护进程,例如 glusterd、ceph
  2. 在每个节点上运行日志收集守护进程,例如 fluentd、logstash
  3. 在每个节点上运行监控守护进程,例如 Prometheus Node Exporter、Sysdig Agent、collectd、Dynatrace OneAgent、APPDynamics Agent、Datadog agent、New Relic agent、Ganglia gmond、Instana Agent 等
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值