天天看點

minikube metrics-server HPA 彈性擴容錯誤

minikube metrics-server pod 錯誤

啟動

minikube addons enable metrics-server

之後檢視

metrics-server

pod 會有如下錯誤

Failed to pull image "k8s.gcr.io/metrics-server-amd64:v0.5.2": rpc error: code = Unknown desc = Error response from daemon: Get https://k8s.gcr.io/v2/: net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers)
           

這個錯誤是

k8s.gcr.io

已經廢棄無法通路,需要替換成在國内的鏡像,可以使用阿裡雲的。

registry.cn-hangzhou.aliyuncs.com/google_containers
           

完整鏡像位址。

registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server-amd64:v0.5.2
           

進入 minikube docker 手動pull鏡像。

minikube ssh
docker pull registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server-amd64:v0.5.2
           

為了讓metrics-server-deployment能工作需要手動打個tag并且讓pod拉取鏡像的規則設定成IfNotPresent。

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/metrics-server:v0.5.2 k8s.gcr.io/metrics-server/metrics-server:v0.5.2
           

如果不做這一步,也可以手動修改deployment image位址,但是這樣比較麻煩。

修改鏡像拉取規則

imagePullPolicy: IfNotPresent
           

手動安裝 metrics-server

如果你本地有其他錯誤,我建議直接關掉minikube metrics-server addons。自行安裝metrics-server。

minikube addons disable metrics-server
           

拉取metrics-server manifast

git://github.com/kubernetes-incubator/metrics-server.git
           

manifast檔案

metrics-server/manifests/base/deployment.yaml

(注意,手動安裝前還需要像第一節介紹的那樣,手動拉取鏡像、修改imagePullPolicy模式。)

可能會出現類似 heapster 之類錯誤。

Error from server (NotFound): the server could not find the requested resource (get services http:heapster:)
           

(注意:heapster模式的測量機制在k8s 1.6之後已經不再使用。需要手動打開控制器管理器hpa-rest拉取測量名額。)

但是minikube controller-manager需要在啟動的時候設定。

kube-system   kube-controller-manager-minikube   1/1     Running   5          2d13h
           

啟動metrics-server測量。

minikube start --extra-config 'controller-manager.horizontal-pod-autoscaler-use-rest-clients=true'
           

hpa 錯誤

建立hpa

k autoscale deployment kubia --cpu-percent=30 --min=1 --max=5
           

檢視hpa狀态

k get hpa

kubia   Deployment/kubia   <unknown>/30%          1         5         5          2d12h
           

檢視詳情

k describe hpa kubia

the HPA was unable to compute the replica count: failed to get cpu utilization: unable to get metrics for resource cpu: no metrics returned from resource metrics API
           

其實這裡的日志是說已經能正常拉取pod的測量,雖然沒有任何傳回,但是不影響使用,我們做個測試。

建立一個應用程式。

apiVersion: apps/v1
kind: Deployment
metadata:
  name: kubia
  labels:
    app: kubia
spec:
  selector:
    matchLabels:
      app: kubia
  replicas: 3
  template:
    metadata:
      labels:
        app: kubia
    spec:
      containers:
      - image: luksa/kubia:v1
        name: kubia
        resources:
          requests:
            cpu: 100m
           

映射一個請求端口。

k expose deployment kubia --port=80 --target-port=8080
           

監控HPA

watch kubectl get hpa

NAME    REFERENCE          TARGETS         MINPODS   MAXPODS   REPLICAS   AGE
kubia   Deployment/kubia   <unknown>/30%   1         5         3          2m34s
           
k run -it --rm --restart=Never loadgenerator --image=busybox -- sh -c "while true; do wget -O -q http://kubia.default; done"
           
NAME    REFERENCE          TARGETS         MINPODS   MAXPODS   REPLICAS   AGE
kubia   Deployment/kubia   51%/30%         1         5         3          3m53s
           
NAME    REFERENCE          TARGETS         MINPODS   MAXPODS   REPLICAS   AGE
kubia   Deployment/kubia   30%/30%         1         5         5          5m12
           

相關版本

minikube version: v1.16.0
           
Client Version: version.Info{Major:"1", Minor:"14", GitVersion:"v1.14.9"}
Server Version: version.Info{Major:"1", Minor:"20", GitVersion:"v1.20.0"}