Kubernetes 官方文档
  • 前言
  • 词汇表
  • 概念
    • 概述
      • 组件
      • 对象
        • 理解 Kubernetes 对象
        • 管理 Kubernetes 对象
        • 对象名称和 ID
        • 标签(Label)和选择算符(Selector)
        • 命名空间(Namespace)
        • 注解(Annotation)
        • 字段选择器
        • Finalizers
        • 属主与附属
    • 架构
      • 节点
    • 工作负载
      • 工作负载资源
        • Job
    • 服务、负载均衡和网络
      • 服务
        • 服务定义
        • 无头服务(Headless Service)
        • 发布服务
    • 配置
      • 配置最佳实践
    • 策略
      • 资源配额
    • 调度、抢占和驱逐
      • Kubernetes 调度器
    • 集群管理
      • 证书
      • 管理资源
        • 组织资源配置
        • kubectl 中的批量操作
        • 有效地使用标签
        • 金丝雀部署
        • 更新标签
      • 集群网络系统
  • 任务
    • 管理集群
      • 手动生成证书
    • 运行应用
      • Pod 水平自动扩缩容
        • HPA 是如何工作的?
      • HPA 演练
        • 创建 HPA
        • 附录
    • TLS
      • 管理集群中的 TLS 认证
  • 参考
    • API 访问控制
      • 使用 RBAC 鉴权
        • API 对象
        • 默认 Roles 和 Role Bindings
        • 初始化与预防权限提升
        • 命令行工具
        • ServiceAccount 权限
        • EndpointSlices 和 Endpoints 写权限
        • 从 ABAC 升级
    • 组件工具
      • kube-scheduler
    • 调度
      • 调度器配置
      • 调度策略
    • 网络参数
      • Service 所用的协议
      • 虚拟 IP 和服务代理
    • 命令行工具 (kubectl)
  • 博客
    • 移除 Dockershim 的常见问题
由 GitBook 提供支持
在本页

这有帮助吗?

在GitHub上编辑
  1. 任务
  2. 运行应用

Pod 水平自动扩缩容

上一页运行应用下一页HPA 是如何工作的?

最后更新于2年前

这有帮助吗?

在 Kubernetes 中, HorizontalPodAutoscaler 自动更新工作负载(例如,Deployment 或者 StatefulSet),目的是自动扩缩容工作负载以满足需求。

水平扩缩容意味着对增加的负载的响应是部署更多的 Pod。这与 “垂直(Vertical)” 扩缩容不同,对于 Kubernetes,垂直扩缩容意味着更多的资源(例如,内存或 CPU)分配给已经为工作负载运行的 Pod。

如果负载减少,并且 Pod 的数量高于配置的最小值,HorizontalPodAutoscaler 会指示工作负载资源缩减。

水平 Pod 自动扩缩容不适用于无法扩缩容的对象(例如,DaemonSet)。

HorizontalPodAutoscaler 被实现为 Kubernetes API 资源和控制器。

资源决定了控制器的行为。在 Kubernetes 控制平成内运行的水平 Pod 自动扩缩容控制器会定期调整其目标(例如,Deployment)的所需规模,以匹配观察到的指标,例如:平均 CPU 利用率、平均内存利用率或指定的任何其他自定义的指标。

使用水平 Pod 自动扩缩容。

API 对象

HorizontalPodAutoscaler 是 Kubernetes autoscaling API 组中的 API 资源。当前的稳定版本可以在 autocaling/v2 API 版本中找到,其中包括对基于内存和自定义指标执行扩缩容的支持。在使用 autoscaling/v1 时,`autoscaling/v2` 中引入 的新字段作为注释保留。

创建 HorizontalPodScaler 对象时,需要确保所给的名称是一个合法的 。有关 API 对象的更多信息,请查阅 。

演练示例
HorizontalPodAutoscaler 对象文档
DNS 子域名