一、HPA介绍

HPA的全称为(Horizontal Pod Autoscaling),通俗的理解下HPA就是对deployment进行扩缩容的一个管理机制,他会监测pod的cpu和memory的使用情况,当cpu或memory达到一个值,为了能够使服务正常运行,他会进行扩容增加pod,来分担压力,当pod的使用比较空闲稳定的时候,他会自动的进行缩容,但缩容的速度远远慢于扩容的速度,防止pod再一次达到阈值。

这是hpa扩容的原理图,其中有个metrics Server的API,HPA控制器通过Metrics Server的API(Heapster的API或聚合API)获取这些数据,基于用户定义的扩缩容规则进行计算,得到目标Pod副本数量。

二、介绍HPA三个版本

我们在使用apiVersion创建资源的时候,有些版本分为很多种,就像hpa,他就有三个版本

第一个版本:autosacling/v1 这是最简单的一个版本,所涵盖的内容比较少,但是使用简单,如果做一些简单的扩缩容可以使用此版本

第二个版本:autoscaling/v2beta1 这是在v1的基础上演变的 多了一个metric模块

第三个版本: autoscaling/v2beta2 这个版本就比较详细了,内容也比较丰富,主要新增了扩缩容灵敏度的控制,下文的例子就是使用的这个版本

我们如果想知道一个apiversion有多少版本的时候 可以使用:  kubectl api-versions |grep 版本名称

kubectl api-resources 还可以查看所有资源

同时kubectl explain  hpa --api-version=autoscaling/v2beta2

还可以指定查看某一个版本下的具体信息

三、HPA实例

我们首先创建一个deploy 然后再创建hpa指定这个deploy进程扩缩容管理

apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  labels:
    app: web
  name: web
spec:
  replicas: 1
  selector:
    matchLabels:
      app: web
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: web
    spec:
      containers:
      - image: nginx:latest
        name: nginx
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 80
        resources:
          limits:
            cpu: "10m"
            memory: 20Mi
          requests:
            cpu: "10m"
            memory: 20Mi
status: {}

# 注意 在创建deploy的时候一定要限制pod的资源配额 资源配额在前几章也说过

下面创建HPA

apiVersion: autoscaling/v2beta2
kind: HorizontalPodAutoscaler
metadata:
  name: web-hpa
spec:
  minReplicas: 1 #最少副本
  maxReplicas: 1000 #最多副本
  scaleTargetRef: #指定目标
    apiVersion: apps/v1
    kind: Deployment
    name: web
  metrics: #对哪个资源进行监控
  - type: Resource
    resource:
      name: cpu
      target:
        type: Utilization
        averageUtilization: 80
  behavior: #这里是重点  设置扩缩容的灵敏度
    scaleUp:
      stabilizationWindowSeconds: 5 # 在五秒之内进程扩容
      policies:
      - type: Percent  #按照百分比进行扩容
        value: 900  #90%
        periodSeconds: 5 %每五秒扩容一次

对于behavior下的polices模块我们还可以这样写

policies:

- type: pods

value: 1

每次只新增一个pod

polices:

- type: pods

value: 0

禁止HPA扩容 (这条我认为没有什么意义,我们使用hpa就是为了进行扩缩容)

结语:

以上就是HPA简单的介绍和操作流程

Kubernetes HPA管理相关推荐

  1. 阿里巴巴 Kubernetes 应用管理实践中的经验与教训

    作者 | 孙健波(阿里巴巴技术专家).赵钰莹 导读:云原生时代,Kubernetes 的重要性日益凸显.然而,大多数互联网公司在 Kubernetes 上的探索并非想象中顺利,Kubernetes 自 ...

  2. 什么是 Kubernetes HPA

    自动伸缩是 Kubernetes 的核心能力.您配置的扩展机制(HPA.VPA 和 Cluster Autoscaler)越严格,运行应用程序的浪费和成本就越低. Kubernetes 提供了三种自动 ...

  3. CoreOS的Tectonic新发行版支持Kubernetes自我管理

    本文讲的是CoreOS的Tectonic新发行版支持Kubernetes自我管理[编者的话]本文详细介绍了CoreOS Tectonic(商业版Kuberbetes)新发型版中的self-hostin ...

  4. 【360开源】Wayne:企业级可视化多集群Kubernetes一站式管理平台

    宣言 Wayne是由360搜索云平台团队开发的,一个通用的.基于Web的Kubernetes多集群一站式可视化管理平台.内置了丰富多样的功能,满足企业的通用需求,同时插件化的方式可以方便集成定制化功能 ...

  5. Kubernetes 权限管理

    2019独角兽企业重金招聘Python工程师标准>>> kubernetes 主要通过 APIServer 对外提供服务,对于这样的系统集群来说,请求访问的安全性是非常重要的考虑因素 ...

  6. Kubernetes权限管理与控制-RBAC

    Kubernetes权限管理与控制-RBAC 1.Kubernetes api访问控制 用户通过kubectl.客户端库或者通过发送REST请求访问API.用户和Kubernetes服务账户都可以被授 ...

  7. Kubernetes HPA 动态弹性扩缩容

    1.HPA 1.1HPA介绍 1.在Kubernetes中,HPA自动更新工作负载资源(例如:Deployment或者StatefulSet),目的是自动扩缩工作负载以满足需求,水平扩缩意味着对增加的 ...

  8. 【K8S专栏】Kubernetes工作负载管理

    微信公众号:运维开发故事,作者:乔克 在Kubernetes中,Pod是最小的管理单元,是一组紧密关联的容器组合. 但是,单独的Pod并不能保障总是可用,比如我们创建一个nginx的Pod,因为某些原 ...

  9. Kubernetes HPA测试

    前言: Kubernetes HPA是指k8s水平扩缩容,一般指的是一个部署好的应用指定了请求cpu内存限制,超过这个限制量会自动进行扩容pod.接下来我们亲自试验hpa吧. 准备工作: 在试验之前, ...

最新文章

  1. ajax跨域解决方案
  2. Curator实现分布式锁的基本原理-LockInternals.internalLockLoop
  3. Happy Valentine's Day
  4. PowerToys 0.19.0 发布,微软开发的免费实用工具集
  5. PyTorch大更新!谷歌出手帮助开发,正式支持TensorBoard | 附5大开源项目
  6. java类的参考文献,太完整了!
  7. gis怎么提取水系_arcgis水系提取流程(dem)
  8. 领航机器人广告段子_医院机器人物流广告词
  9. 从零开始学android:环境搭建
  10. 【计算机视觉】简述对MSAA(多尺度注意力融合)的理解
  11. kali钓鱼(超详细)
  12. Hbuider H5+App获取手机状态栏高度
  13. Nero8直接把APE带CUE映像文件刻录CD方法(转帖)
  14. MySQL无效的月份_ORACLE 插入时间时显示'无效的月份'的问题
  15. 【大数据入门核心技术-HBase】(四)HBase2.2.2高可用集群搭建
  16. 2021-2027全球与中国冰箱稳定器市场现状及未来发展趋势
  17. 一年省下1000亿? 原来零售玩的是闷声发大财
  18. Python集合关系解读:Python语言中都有哪些集合关系?
  19. SystemUI模块总结
  20. Excel 计算重复项中的唯一值的方法

热门文章

  1. Q2营收增长创下3年来最大涨幅,IBM这头大象要在云风口上跳舞?
  2. 天圆地方放样软件_天圆地方放样方法
  3. 【40-系统性能压力测试基本概念-相关性能指标HPSTPSQPSRT-安装Jmeter教程-JMeter测试流程-线程组-取样器-监视器-测试商城首页-JMeter Address 占用的问题】
  4. 异常代码c0000005
  5. MOS管的各项参数解释
  6. Javascript学习历程之表格与表单
  7. 一个程序员的连续套现
  8. 配置SNAT实现共享上网: 搭建内外网案例环境 配置SNAT策略实现共享上网访问
  9. 在南方读研和在北方读研有多大差异?
  10. 关于APP下架的问题