Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【K8s】Kubernetes 稳定性之自动扩缩容

【K8s】Kubernetes 稳定性之自动扩缩容

作者头像
行者Sun
发布于 2024-09-11 10:46:12
发布于 2024-09-11 10:46:12
46700
代码可运行
举报
文章被收录于专栏:KubernetesKubernetes
运行总次数:0
代码可运行

以下内容均来自个人笔记并重新梳理,如有错误欢迎指正!

如果对您有帮助,烦请点赞、关注、转发!如果您有其他想要了解的,欢迎私信联系我~

基本介绍

Kubernetes 中,自动扩缩容是一种动态调整集群资源,以灵活应对应用程序资源需求变化的机制。

自动扩缩容可以分为两个层面:

  • Node 层面:根据业务规模,实现集群节点的自动扩缩容
  • Pod 层面:根据业务规模,实现 Pod 副本的自动扩缩容

自动扩缩容提供了以下好处:

  • 提高资源利用率:根据实际需求动态调整资源,避免资源浪费
  • 提高应用稳定性和可用性:自动应对流量高峰,减少服务中断的风险
  • 简化运维:减少手动干预,自动化资源管理,简化运维工作
  • 成本效益:通过合理的资源分配,降低运营成本

本文将重点介绍几种常见的 Pod 层面自动扩缩容机制。

HPA 机制

Pod 水平自动伸缩(Horizontal Pod Autoscaler,HPA)是 Kubernetes 中最常见的自动扩缩容方式,它可以根据 Pod 实际的负载情况自动增加或减少 Pod 副本的数量。

HPA的工作原理如下:

  • 度量指标:HPA 可以根据 CPU 利用率、内存利用率或其他自定义度量指标来触发扩缩容
  • 目标利用率:设置目标利用率,例如 CPU 的 10%,HPA 会尝试维持这个利用率水平
  • 限制 Pod 数量:可以设置最小和最大 Pod 数量的限制,防止在极端情况下资源的过度使用或不足
  • 缩放策略:HPA 支持不同的缩放策略,如快速缩放、慢速缩放和标准缩放,以适应不同的业务场景
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 创建 HPA 对象
kubectl autoscale deployment demo-deployment --cpu-percent=10 --min=1 --max=10
🔔 --min:指定最小的 Pod 副本数为1
🔔 --max:指定最大的 Pod 副本数为10
🔔 --cpu-percent:指定 Pod 的 CPU 使用率保持在 10%
 
# 查看 HPA 对象
kubectl get hpa
 
# 删除 HPA 对象
kubectl delete hpa demo-deployment

VPA 机制

Pod 垂直自动伸缩(Vertical Pod Autoscaler,VPA)可以根据 Pod 的资源使用情况,自动调整 Pod 的资源请求(Requests)和资源限制(Limits)。

VPA的工作原理如下:

  • 资源分析:VPA 会分析 Pod 的资源使用情况,如 CPU 利用、内存利用
  • 动态调整:VPA 可以动态调整 Pod 的资源请求和资源限制,以优化资源使用和成本

KPA 机制

Pod 基于请求数自动伸缩(Knative Pod Autoscaler,KPA)是一种由 Knative Serving 提供的机制,它可以根据并发请求数及相应的算法,自动增加或减少 Pod 副本的数量,适用于业务流量突发激增的场景。

详细内容请参考技术文档:https://developer.aliyun.com/article/710828

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-09-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 实施运维知识交流 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
K8s pod 动态弹性扩缩容(HPA )部署!步骤齐全,少走坑路
Horizontal Pod Autoscaler(HPA,Pod水平自动伸缩),根据平均 CPU 利用率、平均内存利用率或你指定的任何其他自定义指标自动调整 Deployment 、ReplicaSet 或 StatefulSet 或其他类似资源,实现部署的自动扩展和缩减,让部署的规模接近于实际服务的负载。HPA不适用于无法缩放的对象,例如DaemonSet。
民工哥
2022/10/27
7.8K0
K8s pod 动态弹性扩缩容(HPA )部署!步骤齐全,少走坑路
K8S之HPA自动扩缩容机制
kubectl scale 命令可以来实现 Pod 的扩缩容功能,但是这个毕竟是完全手动操作的,要应对线上的各种复杂情况,我们需要能够做到自动化去感知业务,来自动进行扩缩容。为此,Kubernetes 也为我们提供了这样的一个资源对象: Horizontal Pod Autoscaling(Pod 水平自动伸缩) ,简称 HPA ,HPA 通过监控分析一些控制器控制的所有 Pod 的负载变化情况来确定是否需要调整 Pod 的副本数量
tunsuy
2023/08/19
1.2K0
K8S之HPA自动扩缩容机制
k8s中pod的自动扩缩容
Kubernetes从1.1版本开始, 新增了名为Horizontal Pod Autoscaler(HPA) 的控制器, 用于实现基于CPU使用率进行自动Pod扩缩容的功能。 HPA控制器基于Master的kube-controller-manager服务启动参数–horizontal-pod-autoscaler-sync-period定义的探测周期(默认值为15s) , 周期性地监测目标Pod的资源性能指标, 并与HPA资源对象中的扩缩容条件进行对比, 在满足条件时对Pod副本数量进行调整。Kubernetes在早期版本中, 只能基于Pod的CPU使用率进行自动扩缩容操作, 关于CPU使用率的数据来源于Heapster组件。 Kubernetes从1.6版本开始, 引入了基于应用自定义性能指标的HPA机制, 并在1.9版本之后逐步成熟。
dogfei
2020/08/06
3.7K0
k8s中pod的自动扩缩容
k8s 中 pod 的自动扩缩容
Horizontal Pod Autoscaler(HPA)控制器, 用于实现基于 CPU 使用率进行自动 Pod 扩缩容的功能。HPA 控制器基于 Master 的 kube-controller-manager 服务启动参数 --horizontal-pod-autoscaler-sync-period 定义的探测周期(默认值为 15s) , 周期性地监测目标 Pod 的资源性能指标, 并与 HPA 资源对象中的扩缩容条件进行对比, 在满足条件时对 Pod 副本数量进行调整。
yxxhero
2022/05/31
1.3K0
k8s 中 pod 的自动扩缩容
kubernetes(十六) k8s 弹性伸缩
常规的做法是给集群资源预留保障集群可用,通常20%左右。这种方式看似没什么问题,但放到Kubernetes中,就会发现如下2个问题。
alexhuiwang
2020/09/23
4K0
kubernetes(十六) k8s 弹性伸缩
云原生-什么是HPA和PDB、VPA
HPA是Horizontal Pod Autoscaler的缩写,它在Kubernetes中允许根据应用程序的负载动态调整Pod的副本数量,从而使得应用程序能够自动扩展或收缩,以适应变化的工作负载,进而提高资源利用率和应用程序的性能。
章工运维
2024/02/29
8530
研发工程师玩转Kubernetes——自动扩缩容
在《研发工程师玩转Kubernetes——使用Deployment进行多副本维护》一文中,我们通过Deployment实现了多副本维护——即维持在一个确定数量的副本个数。而在现实场景中,我们往往需要根据服务的压力,采用水平(横向)扩容的方式——即增加多个副本,来分担压力。当服务压力降低时,又需要减少副本数来节约成本。本节我们将介绍如何根据服务压力进行自动的扩缩容。
方亮
2023/05/26
5090
研发工程师玩转Kubernetes——自动扩缩容
一文搞懂使用 KEDA 实现 Kubernetes 自动弹性伸缩
Hello folks,我是 Luga,今天我们来聊一下云原生生态领域相关的技术 - Auto Scaling ,即 “弹性伸缩” 。
Luga Lee
2023/12/26
3.4K0
一文搞懂使用 KEDA 实现 Kubernetes 自动弹性伸缩
Kubernetes自动伸缩机制,为你降本增效
从技术上讲,容器化应用能该帮助组织更具有成本的优势,但Kubernetes到处布满了成本陷阱,可能会使你超出预算。幸运的是,有一些策略可以控制云成本,自动伸缩就是其中之一。Kubernetes带有三个内置的自动伸缩机制来帮助你做到这一点。它们配合得越好,运行应用程序的成本就越低。
kubernetes中文社区
2021/08/12
1.4K0
13.深入k8s:Pod 水平自动扩缩HPA及其源码分析
Pod 水平自动扩缩全名是Horizontal Pod Autoscaler简称HPA。它可以基于 CPU 利用率或其他指标自动扩缩 ReplicationController、Deployment 和 ReplicaSet 中的 Pod 数量。
luozhiyun
2020/10/10
2.8K0
13.深入k8s:Pod 水平自动扩缩HPA及其源码分析
Kubernetes的垂直和水平扩缩容的性能评估
译自:Performance evaluation of the autoscaling strategies vertical and horizontal using Kubernetes
charlieroro
2022/12/30
1.8K0
Kubernetes的垂直和水平扩缩容的性能评估
再战 k8s(13):Pod 的扩缩容
实际生产系统, 会遇到某个服务需要扩容的场景,也可能会遇到由于资源紧张或者工作负载降低而需要减少服务实例数量的场景。
看、未来
2022/05/06
9120
再战 k8s(13):Pod 的扩缩容
k8s滚动升级和扩缩容
用于实现基于CPU使用率进行自动Pod扩缩容的功能。HPA控制器基于Master的kube-controller-manager服务启动参数--horizontal-pod-autoscaler-sync-period定义的探测周期(默认值为 15s),周期性地监测目标Pod的资源性能指标,并与HPA资源对象中的扩缩容条件进行对比,在满足条件时对Pod副本数量进行调整.
丁D
2022/08/12
1.8K0
Kubernetes HPA:智能缩放应用以应对访问高峰
我们都知道,应用的流量可以说是波动不定。一款应用可能会在某个时间点突然遭遇巨大的访问量,而在其他时候则可能门可罗雀。为了应对这种情况,自动化缩放服务成为了维持服务稳定性和成本效率的关键。今天我们将介绍 Kubernetes 的一个强大功能 —— 水平Pod自动伸缩(Horizontal Pod Autoscaler,简称HPA),它可以帮助我们智能地调整应用的规模。
希里安
2024/01/31
1930
Kubernetes HPA:智能缩放应用以应对访问高峰
Kubernetes(k8s)-自动扩缩工作负载(HPA)
作者介绍:简历上没有一个精通的运维工程师。下面的思维导图也是预计更新的内容和当前进度(不定时更新)。
运维小路
2025/03/28
1720
Kubernetes(k8s)-自动扩缩工作负载(HPA)
k8s群集之动态扩缩容——HPA
HPA的全称为Horizontal Pod Autoscaling,它可以根据当前pod资源的使用率(如CPU、磁盘、内存等),进行副本数的动态的扩容与缩容,以便减轻各个pod的压力。当pod负载达到一定的阈值后,会根据扩缩容的策略生成更多新的pod来分担压力,当pod的使用比较空闲时,在稳定空闲一段时间后,还会自动减少pod的副本数量。
小手冰凉
2020/09/15
2.9K0
k8s多维度自动弹性伸缩
最新版 HPA:autoscaling/v2beta1,有四种类型的 metrics
kinnylee
2022/07/01
1.7K0
Kubernetes 笔记 012 Pod 的自动扩容与缩容
K8S 作为一个集群式的管理软件,自动化、智能化是免不了的功能。Google 在 K8S v1.1 版本中就加入了这个 Pod 横向自动扩容的功能(Horizontal Pod Autoscaling,简称 HPA)。
Linux云计算网络
2019/05/25
1.1K0
自动扩缩容HPA实践(一)
在Kubernetes中,HPA(Horizontal Pod Autoscaler)是一种自动扩缩容应用程序的方式,可以根据应用程序负载动态调整Pod副本数量。HPA是一个非常有用的功能,它可以帮助您实现自动水平扩展和收缩应用程序,并确保应用程序始终能够处理负载。
玖叁叁
2023/04/30
6340
Kubernetes运维之容器编排Deployment动态扩缩容
HPA(Horizontal Pod Autoscaler)的实现是一个控制循环,由controller manager的–horizontal-pod-autoscaler-sync-period参数指定周期(默认值为15秒)。每个周期内,controller manager根据每个HorizontalPodAutoscaler定义中指定的指标查询资源利用率。controller manager可以从resource metrics API(pod 资源指标)和custom metrics API(自定义指标)获取指标。
王先森sec
2023/04/24
1.2K0
Kubernetes运维之容器编排Deployment动态扩缩容
相关推荐
K8s pod 动态弹性扩缩容(HPA )部署!步骤齐全,少走坑路
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验