下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

【云原生】K8s Pod 定时弹性伸缩Cronhpa介绍与实战操

作者:匿名     来源: 云计算点击数:495发布时间: 2022-12-28 20:12:24

标签: K8sCronhpa定时弹性

  您可以使用 CronHorizontalPodAutoscaler 使用在 Kubernetes 中定义的任何种类对象,这些对象支持 scale 子资源(如 Deployment 和 StatefulSet)。

  一、概述

  其实原生的HPA是不支持根据时间点来进行扩缩容的,根据时间点扩缩容其实在有些场景下还是蛮实用的,因为根据资源扩缩容无法精准控制,像在大数据领域,跑任务的时间段一般是明确的,这样我们就可以根据跑任务的时间段来进行pod扩缩容,这样就非常精准的控制资源使用了。这里主要介绍阿里开源的一个产品kubernetes-cronhpa-controller;kubernetes-cronhpa-controller 是一个 Kubernetes cron 水平 Pod 自动缩放控制器,使用 crontab 喜欢方案。您可以使用 CronHorizontalPodAutoscaler 使用在 Kubernetes 中定义的任何种类对象,这些对象支持 scale 子资源(如 Deployment 和 StatefulSet)。

  GitHub地址:https://github.com/AliyunContainerService/kubernetes-cronhpa-controller

  k8s环境部署可以参考:「云原生」Kubernetes(k8s)最完整版环境部署(V1.24.1)

  关于原生的HPA介绍与使用可以参考:【云原生】K8s pod 动态弹性扩缩容 HPA(metrics-server)

  二、cronhpa 安装

  复制

  1.  # 下载

  2.  git clone https://github.com/AliyunContainerService/kubernetes-cronhpa-controller.git

      3.

  4.  # 1、install CRD

  5.  # k8s < v1.22

  6.  #kubectl apply -f config/crds/autoscaling.alibabacloud.com_cronhorizontalpodautoscalers.yaml

  7.  # k8s >=v1.22

  8.  kubectl apply -f config/crds/autoscaling.alibabacloud.com_cronhorizontalpodautoscalers.v1.22.yaml

      9.

  10.  # 2、install RBAC settings

  11.  kubectl apply -f config/rbac/rbac_role.yaml

  12.  kubectl apply -f config/rbac/rbac_role_binding.yaml

      13.

  14.  # 3、deploy kubernetes-cronhpa-controller

  15.  kubectl apply -f config/deploy/deploy.yaml

      16.

  17.  # 4、verify installation

  18.  kubectl get deploy kubernetes-cronhpa-controller -n kube-system -o wide

  三、测试验证

  复制

  1.  ---

  2.  apiVersion: apps/v1 # for versions before 1.8.0 use apps/v1beta1

  3.  kind: Deployment

  4.  metadata:

  5.  name: nginx-deployment-basic

  6.  labels:

  7.  app: nginx

  8.  spec:

  9.  replicas: 2

  10.  selector:

  11.  matchLabels:

  12.  app: nginx

  13.  template:

  14.  metadata:

  15.  labels:

  16.  app: nginx

  17.  spec:

  18.  containers:

  19.  - name: nginx

  20.  image: nginx:1.7.9 # replace it with your exactly <image_name:tags>

  21.  ports:

  22.  - containerPort: 80

  23.  ---

  24.  apiVersion: autoscaling.alibabacloud.com/v1beta1

  25.  kind: CronHorizontalPodAutoscaler

  26.  metadata:

  27.  labels:

  28.  controller-tools.k8s.io: "1.0"

  29.  name: cronhpa-sample

  30.  spec:

  31.  scaleTargetRef:

  32.  apiVersion: apps/v1

  33.  kind: Deployment

  34.  name: nginx-deployment-basic

  35.  jobs:

  36.  - name: "scale-down"

  37.  schedule: "30 */1 * * * *" # 秒,分,时、日、月、周,比Linux crontab更细粒度到秒了。每30秒缩容一次。

  38.  targetSize: 1 # 缩容到1 pod

  39.  - name: "scale-up"

  40.  schedule: "01 */1 * * * *" # 每分钟第一秒就扩容一次

  41.  targetSize: 3 # 扩容到3 pod

  执行

  复制

  1.  kubectl apply -f examples/deployment_cronhpa.yaml

  2.  kubectl get pods,deploy

      3.

  4.  # 查看cronhpa

  5.  kubectl describe cronhpa cronhpa-sample

  部署和使用都非常简单,理解也非常简单,其实实现也不难,我们自己写crontab也是可以实现的,但是没有那么好,功能虽然简单,但是还是非常实用的。​

  来源: 今日头条

    >>>>>>点击进入计算专题

赞(12)
踩(0)
分享到:
华为认证网络工程师 HCIE直播课视频教程