当前位置: 首页 > news >正文

DaemonSet 与 Deployment 的主要区别

DaemonSetDeployment 都是 Kubernetes 中常用的控制器(Controller),但它们的用途和行为有所不同。下面是它们的主要区别:

1. 目标用途:

  • DaemonSet: 用于在集群中的每个节点上运行一个 Pod。它确保每个节点上都部署有该 Pod,通常用于运行一些需要在每个节点上都存在的应用程序或服务(例如,日志收集器、监控代理、网络代理等)。
  • Deployment: 用于管理一组副本的 Pod,它确保指定数量的 Pod 副本在集群中运行。Deployment 通常用于无状态应用程序的部署(例如 Web 服务、API 服务器等),可以方便地进行滚动更新、回滚等操作。

2. Pod 分配方式:

  • DaemonSet: 在每个节点上都部署一个 Pod,确保每个节点都有该 Pod 的副本。如果你有新的节点加入集群,DaemonSet 会自动在新节点上启动 Pod。
  • Deployment: Pod 根据调度策略分配到不同节点,通常不会保证每个节点上都有 Pod。你可以指定副本数量,Deployment 会根据集群资源调度 Pods 到合适的节点。

3. 控制的 Pod 数量:

  • DaemonSet: 在每个节点上至少有一个 Pod,所以 Pod 的数量通常等于集群中的节点数。如果有 5 个节点,DaemonSet 会创建 5 个 Pod。
  • Deployment: 根据副本数来控制 Pod 数量,例如,设置副本数为 3,那么 Deployment 会确保集群中有 3 个相同的 Pod。

4. 更新策略:

  • DaemonSet: 更新策略可以配置为滚动更新,但是由于每个节点上都有 Pod,所以更新时可能会涉及到每个节点的 Pod 升级。对于每个节点的 Pod,DaemonSet 会逐个进行更新,确保不中断集群中正在运行的服务。
  • Deployment: 支持滚动更新,Deployment 会逐个替换 Pod 副本,直到所有副本更新完成,且不会影响集群中的服务可用性。

5. 删除行为:

  • DaemonSet: 删除时,DaemonSet 会删除所有节点上的 Pod,通常这些 Pod 是直接绑定到节点的,所以删除时要非常小心。
  • Deployment: 删除时,Deployment 会按照副本数删除 Pod,直到没有 Pod 副本为止。

6. 典型用例:

  • DaemonSet: 用于部署每个节点上都需要的服务或代理,例如日志收集器(Fluentd、Logstash)、监控代理(Prometheus Node Exporter)等。
  • Deployment: 用于部署应用程序或服务,需要控制副本数和负载均衡,常用于 Web 应用、API 服务等。

7. Pod 生命周期:

  • DaemonSet: 当节点被加入集群时,DaemonSet 会自动在新节点上启动 Pod;当节点被删除时,DaemonSet 会删除节点上的 Pod。
  • Deployment: Pod 根据副本数的配置进行管理,不会特别关注节点的数量变化。

简要总结

特性DaemonSetDeployment
目标用途在每个节点上运行一个 Pod管理无状态应用的多个 Pod副本
Pod 分配方式每个节点上一个 Pod根据副本数调度 Pod 到集群中的各节点
副本数量等于节点数根据设置的副本数(如 3 个副本)
更新策略支持滚动更新支持滚动更新和回滚
删除行为删除所有节点上的 Pod删除指定副本数的 Pod
典型用例节点上运行代理或服务(如日志收集)管理 Web 应用或其他服务的副本

根据你的需求选择合适的控制器。如果你需要在每个节点上都运行服务,DaemonSet 是更好的选择;如果你要管理多个副本的应用程序,Deployment 更为合适。

相关文章:

  • 使用 Layers 扩展你的 Nuxt4 应用
  • VScode-i18n-ally-Vue
  • “线程通信“一个案例
  • 仓储物流中UWB标签实现货物实时追踪的技术路径与品铂科技方案解析
  • MySQL、创建数据库、表、SQL 函数:数学函数、字符串函数、日期函数、聚合函数
  • 怎么使用pm2启动和暂停后端程序(后端架构nodejs+koa)
  • 【学Rust写CAD】14线性插值函数(加入color.rs)
  • Docker 快速入门指南
  • 【安全运营】关于攻击面管理相关概念的梳理(二)
  • Ubuntu 24.04 安装 Docker 详细教程
  • SQL server中的事务与锁
  • 华为HG532路由器RCE漏洞 CVE-2017-17215 复现
  • 批量给 PDF 页面添加超链接
  • Flink实战教程从入门到精通(基础篇)(五)Flink部署-YARN运行模式
  • 风险研究 | AI 安全警钟响起:Manus AI 漏洞暴露的背后真相
  • LeetCode 第36、37题(数独问题)
  • spring ApplicationContext 继承的这些接口作用,示例,表格对比
  • 华为单臂路由 与 策略路由
  • SpringCould微服务架构之Docker(4)
  • chrome插件开发之API解析-chrome.scripting.executeScript()
  • linux php网站部署/深圳网络seo推广
  • 网站用axure做的rp格式/网站推广平台搭建
  • 做美食网站的图片/网址申请注册
  • 网站开发员纵向发展/长沙网络推广只选智投未来
  • 网站建设公司做网站要多少费用/最近的新闻事件
  • 四川省住房和建设厅官方网站/网络营销产品推广方案