您可以使用 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也是可以实现的,但是没有那么好,功能虽然简单,但是还是非常实用的。
来源: 今日头条
>>>>>>点击进入云计算专题
上一篇:CIO容易犯的优秀云战略错误
下一篇:华为认证的7个企业云战略趋势
¥10500.00
¥99.00
¥499.00
¥499.00