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

公众号关注 「奇妙的 Linux 世界」

设为「星标」,每天带你玩转 Linux !

863643a83e789cabdd8800f55511e24d.jpeg

一、概述

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

0d2dcfb22decf71283215803f386f4c6.png

二、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

fb929f59f86f121db42f0c3e52509148.png

三、测试验证

---
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

6d9e3069781a899b1c30a550a1ec2689.png

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

本文转载自:「大数据与云原生技术分享」,原文:https://tinyurl.com/mscxdpp4,版权归原作者所有。欢迎投稿,投稿邮箱: editor@hi-linux.com。

e74841970d7d3811b6c96708cd3ec9a4.gif

最近,我们建立了一个技术交流微信群。目前群里已加入了不少行业内的大神,有兴趣的同学可以加入和我们一起交流技术,在 「奇妙的 Linux 世界」 公众号直接回复 「加群」 邀请你入群。

b4103a3e44631db3ad4831f5276ce4a2.png

你可能还喜欢

点击下方图片即可阅读

b5c8982fbbea27298ea8908f2bb00a9b.jpeg

『言论集』03 期 :谈谈程序员•职场和自律

b6df8608c7a13b937f9e8143ecc2af82.png
点击上方图片,『美团|饿了么』外卖红包天天免费领

165d03fb9bc773eb5c1889d4d0e4fe3d.png

更多有趣的互联网新鲜事,关注「奇妙的互联网」视频号全了解!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值