飞天使-k8s知识点13-kubernetes散装知识点2-statefulset&daemonset

文章目录

RC RS Deployment
StatefulSet有状态服务控制器
statefulset 

StatefulSet 是 Kubernetes 1.9 版本引入的一个新的 API 对象,主要用于处理有状态的服务。StatefulSet 与 Deployment 类似,都可以保证在集群中运行指定数量的 Pod 副本,但 StatefulSet 提供了一些额外的特性来处理有状态应用的特殊需求:

稳定的网络标识符:StatefulSet 中的每个 Pod 都有一个稳定的、预测性的名称,这个名称在 Pod 的生命周期中不会改变。

稳定的存储:StatefulSet 可以使用 Persistent Volumes,这样即使 Pod 被重新调度,它的数据也不会丢失。

有序的部署和扩展:当你部署或扩展 StatefulSet,Pods 会按照顺序一个接一个地启动。同样,当你缩小 StatefulSet 的规模时,Pods 会按照相反的顺序一个接一个地关闭。

有序的删除和终止:当你删除 StatefulSet 时,Pods 会按照相反的顺序一个接一个地被删除。

这些特性使得 StatefulSet 特别适合运行需要稳定网络标识符和稳定存储的有状态应用,例如数据库。



在 Kubernetes 中,Headless Service 是一种特殊类型的 Service,它没有分配 Cluster IP,因此不会进行负载均衡和代理。这种类型的 Service 通常在你不需要 Service-level 负载均衡,或者更想要直接访问 Pod 的网络地址时使用。

当你查询 Headless Service 的 DNS 名称时,DNS 服务器将返回与该 Service 关联的所有 Pod 的 IP 地址列表,而不是返回 Service 的 Cluster IP。这使得其他应用可以直接与运行在特定 Pod 上的服务进行通信,而不是通过 Service 进行通信。

Headless Service 在有状态应用(例如数据库集群)中特别有用,因为这些应用通常需要直接访问特定的 Pod 实例。



在 Kubernetes 中,volumeClaimTemplates 是 StatefulSet 规格中的一个字段,它允许每个 Pod 自动创建和挂载自己的持久卷(Persistent Volume)。这是有状态应用,如数据库,需要的功能,因为每个数据库实例通常需要自己的存储,这样它就可以保持其状态。

volumeClaimTemplates 是 PersistentVolumeClaim 对象的模板列表。当 Kubernetes 为 StatefulSet 创建新的 Pod 时,它会为每个模板创建一个新的 PersistentVolumeClaim。然后,这些 PersistentVolumeClaim 会被用来动态地为 Pod 分配 Persistent Volumes。

这种方式的好处是,即使 Pod 被删除或迁移到集群中的其他节点,其数据也会保持不变,因为 Persistent Volume 的生命周期独立于 Pod。
DaemonSet守护进程与任务
在 Kubernetes 中,DaemonSet 是一种资源对象,它确保在集群中的每个节点上都运行一个 Pod 的副本。如果有新节点添加到集群,DaemonSet 就会为这些节点添加 Pod。同样,如果从集群中删除节点,那么这些节点上的 Pod 也将被垃圾回收。

DaemonSet 特别适合运行集群范围的系统服务,例如日志收集器(如 Fluentd 或 Logstash)、监控服务(如 Prometheus Node Exporter)或网络插件(如 Weave、Calico 或 Flannel)。这些类型的应用通常需要在每个节点上运行,以便它们可以收集或处理所有节点的信息。
job cronjob
job 一次性任务
cronjob 定时计划任务,linux 中crontab 类似
相关推荐
元气满满的热码式6 小时前
K8S中Service详解(一)
云原生·容器·kubernetes
元气满满的热码式10 小时前
K8S中ingress详解
云原生·容器·kubernetes
jcrose258010 小时前
Ubuntu二进制部署K8S 1.29.2
linux·ubuntu·kubernetes
lozhyf10 小时前
基于 JFinal 的国产微服务框架
微服务·云原生·架构
matrixlzp10 小时前
K8S 启动探测、就绪探测、存活探测
云原生·容器·kubernetes
Dusk_橙子10 小时前
在K8S中,如何使用EFK实现日志的统一管理?
云原生·容器·kubernetes
Tony115410 小时前
Kubernetes v1.28.0安装dashboard v2.6.1(k8s图形化操作界面)
云原生·容器·kubernetes
龙胖不下锅10 小时前
k8s资源预留
云原生·容器·kubernetes
超级阿飞10 小时前
利用Kubespray安装生产环境的k8s集群-排错篇
docker·容器·kubernetes
喝醉酒的小白10 小时前
在 Kubernetes 上快速安装 KubeSphere v4.1.2
云原生·容器·kubernetes