日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
【云原生】K8sPod定時彈性伸縮Cronhpa介紹與實戰(zhàn)操

【云原生】K8S Pod 定時彈性伸縮Cronhpa介紹與實戰(zhàn)操

作者:大數(shù)據(jù)老司機 2022-12-26 08:14:57
云計算
云原生 您可以使用 CronHorizontalPodAutoscaler 使用在 Kubernetes 中定義的任何種類對象,這些對象支持 scale 子資源(如 Deployment 和 StatefulSet)。

成都創(chuàng)新互聯(lián)服務(wù)項目包括臨城網(wǎng)站建設(shè)、臨城網(wǎng)站制作、臨城網(wǎng)頁制作以及臨城網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,臨城網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到臨城省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

一、概述

其實原生的HPA是不支持根據(jù)時間點來進行擴縮容的,根據(jù)時間點擴縮容其實在有些場景下還是蠻實用的,因為根據(jù)資源擴縮容無法精準控制,像在大數(shù)據(jù)領(lǐng)域,跑任務(wù)的時間段一般是明確的,這樣我們就可以根據(jù)跑任務(wù)的時間段來進行pod擴縮容,這樣就非常精準的控制資源使用了。這里主要介紹阿里開源的一個產(chǎn)品kubernetes-cronhpa-controller;kubernetes-cronhpa-controller 是一個 Kubernetes cron 水平 Pod 自動縮放控制器,使用 crontab 喜歡方案。您可以使用 CronHorizontalPodAutoscaler 使用在 Kubernetes 中定義的任何種類對象,這些對象支持 scale 子資源(如 Deployment 和 StatefulSet)。

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

k8s環(huán)境部署可以參考:「云原生」Kubernetes(k8s)最完整版環(huán)境部署(V1.24.1)

關(guān)于原生的HPA介紹與使用可以參考:【云原生】K8s pod 動態(tài)彈性擴縮容 HPA(metrics-server)

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

三、測試驗證

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

執(zhí)行

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

# 查看cronhpa
kubectl describe cronhpa cronhpa-sample

部署和使用都非常簡單,理解也非常簡單,其實實現(xiàn)也不難,我們自己寫crontab也是可以實現(xiàn)的,但是沒有那么好,功能雖然簡單,但是還是非常實用的。?


新聞標題:【云原生】K8sPod定時彈性伸縮Cronhpa介紹與實戰(zhàn)操
網(wǎng)站鏈接:http://www.5511xx.com/article/djipdcg.html