Azure Kubernetes 水平自動擴充Pod,新手必須掌握kubernetes架構Azure Kubernetes水平并自動擴展Pod當我們將應用部署到AKS以pod的形式提供外部服務時,為了保證用戶能夠獲得良好的體驗,我們需要注意以下兩種情況:服務不可用,因為POD未知掛斷。當大量用戶訪問時,Pod能否在高負......
當我們將應用部署到AKS以pod的形式提供外部服務時,為了保證用戶能夠獲得良好的體驗,我們需要注意以下兩種情況:
服務不可用,因為POD未知掛斷。
當大量用戶訪問時,Pod能否在高負載下支持我們的應用?
對于Pod的高可用性,我們可以使用AKS的部署控制器來保證Pod能夠持續提供外部服務。但是,當面對大量的用戶訪問時,我們需要擴展我們的資源來滿足業務需求。在上一篇文章中,介紹了您手動擴展pods來滿足業務擴展需求,但是相信大家都已經意識到,如果我們手動監控Pods,手動調整副本,那么這個工作量無疑是巨大的,但是kubernetes已經有了相應的機制來應對。這就是我們今天要給大家介紹的水平自動擴展POD(HPA)HPA的工作流程,全稱水平POD自動縮放控制器。
HPA的工作流程如下:
創建HPA資源對象,關聯部署等相應資源,設置目標CPU利用率閾值、最大最小副本數。前提:pod必須設置資源限制,參數請求才會讓HPA工作。
每隔15秒(可以通過設置controller manager的–horizontalpodauto scalersyncperiod參數來設置,默認為15秒),HPA控制器通過觀察度量值來獲取資源使用信息。
HPA控制器將獲取的資源使用信息與HPA設置值進行比較,并計算要調整的副本數量。
根據計算結果調整副本數量,使單個POD的CPU利用率盡可能接近期望值,但無法兼顧設定的最大值和最小值。
上述2、3、4個周期
說了這么多,我們來看看如何配置HPA:在配置HPA之前,我們需要先了解節點的配置檢查并配置資源限制使用kubectl get nodes命令檢查節點信息(節點名)并使用kubectl describe nodes NODENAME命令確認節點資源配置狀態。因為之前沒有配置資源quata,所以需要先設置資源限制:打開之前創建的yaml文件,修改資源配置,其中CPU配置容器只使用一個CPU單元,請求限制使用0.5個CPU單元;修改之后,使用kubectl apply f FILENAME來重新部署相應的POD。
設置水平自動擴展HPA使用命令ku bectl autoscale deployment nginxCPUpercent = 1min = 1max = 10將自動擴展設置為1%,并將最小副本數設置為1,最大副本數設置為10。
配置完成后,我們使用webbench對我們部署的NGINX網站進行壓力測試:使用命令kubectl get hpa觀察自動水平擴展的狀態。請注意,Target中有兩個數字。是,當前/目標CPU利用率。使用命令kubectl get deployment觀察部署的數量是否增加了。使用命令kubectl get pod來觀察pod的數量是否增加了,并注意狀態。如果為1,則表示水平自動擴展(hpa)設置成功且有效。
清除資源測試完成后,我們可以使用kubect delete f FILENAME刪除對應的部署資源:使用kubectl delete hpa nginx刪除hpa資源:
特別聲明:以上文章內容僅代表作者本人觀點,不代表ESG跨境電商觀點或立場。如有關于作品內容、版權或其它問題請于作品發表后的30日內與ESG跨境電商聯系。
二維碼加載中...
使用微信掃一掃登錄
使用賬號密碼登錄
平臺顧問
微信掃一掃
馬上聯系在線顧問
小程序
ESG跨境小程序
手機入駐更便捷
返回頂部