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

    作者:匿名更新于: 2022-12-28 20:12:24

      您可以使用 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

      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也是可以实现的,但是没有那么好,功能虽然简单,但是还是非常实用的。​

      来源: 今日头条

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

云计算 更多推荐

课课家教育

未登录

1