Kubernetes Pod 定时弹性伸缩控制器 Cronhpa 中文入门教程

 互联网   2023-05-08 11:59   1291 人阅读  0 条评论
Kubernetes Pod 定时弹性伸缩控制器 Cronhpa 中文入门教程  第1张

一、概述

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

Kubernetes Pod 定时弹性伸缩控制器 Cronhpa 中文入门教程  第2张

二、cronhpa 安装

# 下载
git clone https://github.com/AliyunContainerService/kubernetes-cronhpa-controller.git

# 1、install CRD
# k8s < v1.22
#kubectl apply -f config/crds/autoscaling.alibabacloud.com_cronhorizontalpodautoscalers.yaml
# k8s >=v1.22
kubectl apply -f config/crds/autoscaling.alibabacloud.com_cronhorizontalpodautoscalers.v1.22.yaml

# 2、install RBAC settings
kubectl apply -f config/rbac/rbac_role.yaml
kubectl apply -f config/rbac/rbac_role_binding.yaml

# 3、deploy kubernetes-cronhpa-controller
kubectl apply -f config/deploy/deploy.yaml

# 4、verify installation
kubectl get deploy kubernetes-cronhpa-controller -n kube-system -o wide

Kubernetes Pod 定时弹性伸缩控制器 Cronhpa 中文入门教程  第3张

三、测试验证

---
apiVersion: apps/v1 # for versions before 1.8.0 use apps/v1beta1
kind: Deployment
metadata:
 name: nginx-deployment-basic
 labels:
   app: nginx
spec:
 replicas: 2
 selector:
   matchLabels:
     app: nginx
 template:
   metadata:
     labels:
       app: nginx
   spec:
     containers:
     - name: nginx
       image: nginx:1.7.9 # replace it with your exactly <image_name:tags>
       ports:
       - containerPort: 80
---
apiVersion: autoscaling.alibabacloud.com/v1beta1
kind: CronHorizontalPodAutoscaler
metadata:
 labels:
   controller-tools.k8s.io: "1.0"
 name: cronhpa-sample
spec:
  scaleTargetRef:
     apiVersion: apps/v1
     kind: Deployment
     name: nginx-deployment-basic
  jobs:
  - name: "scale-down"
    schedule: "30 */1 * * * *" # 秒,分,时、日、月、周,比Linux crontab更细粒度到秒了。每30秒缩容一次。
    targetSize: 1 # 缩容到1 pod
  - name: "scale-up"
    schedule: "01 */1 * * * *" # 每分钟第一秒就扩容一次
    targetSize: 3 # 扩容到3 pod

执行

kubectl apply -f examples/deployment_cronhpa.yaml
kubectl get pods,deploy

# 查看cronhpa
kubectl describe cronhpa cronhpa-sample

Kubernetes Pod 定时弹性伸缩控制器 Cronhpa 中文入门教程  第4张

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



本文转载自:「大数据与云原生技术分享」,原文:https://tinyurl.com/mscxdpp4,版权归原作者所有。



本文地址:https://dockerworld.cn/?id=318
温馨提示:文章内容系作者个人观点,不代表Docker中文社区对观点赞同或支持。
版权声明:本文为转载文章,来源于 互联网 ,版权归原作者所有,欢迎分享本文,转载请保留出处!

 发表评论


表情

还没有留言,还不快点抢沙发?