当我执行kubectl顶部吊舱/节点时,出现以下错误:
指标尚不可用
当我查看日志时
$ kubectl logs metrics-server-7df4c4484d-h75wr -n kube-system -c metrics-server
I1008 12:02:55.159069 1 serving.go:273] Generated self-signed cert(apiserver.local.config/certificates/apiserver.crt, apiserver.local.config/certificates/apiserver.key)
[restful] 2018/10/08 12:02:56 log.go:33: [restful/swagger] listing is available at https://:443/swaggerapi
[restful] 2018/10/08 12:02:56 log.go:33: [restful/swagger] https://:443/swaggerui/ is mapped to folder /swagger-ui/
I1008 12:02:56.358063 1 serve.go:96] Serving securely on [::]:443
E1008 12:03:04.225519 1 reststorage.go:101] unable to fetch node metrics for node "hpa-test": no metrics known for node "hpa-test"
E1008 12:03:07.619489 1 reststorage.go:101] unable to fetch node metrics for node "hpa-test": no metrics known for node "hpa-test"
此外,我能够从以下位置ping到hpa-test节点:
$ kubectl exec -it metrics-server-7df4c4484d-h75wr -n kube-system sh
此外,我尝试过在各处寻找解决方案,但没有解决问题的方法
答案 0 :(得分:4)
有两种方法可以解决此问题:
1)使用堆: 安装heapster可以使'kubectl顶级节点'开箱即用。但是不推荐使用heapster,因此您可能应该切换到metrics-server。
2)使用 metrics-server : 不幸的是,在安装metrics-server时,它可能开箱即用。 如果没有,则需要更新用于安装的metrics-server-deployment.yaml(1.8+)文件的末尾,并使用正确的参数添加命令部分,如下所示:
containers:
- name: metrics-server
image: k8s.gcr.io/metrics-server-amd64:v0.3.1
imagePullPolicy: Always
volumeMounts:
- name: tmp-dir
mountPath: /tmp
command:
- /metrics-server
- --kubelet-insecure-tls
- --kubelet-preferred-address-types=InternalIP
然后只需应用更改:
kubectl apply -fmetrics-server-deployment.yaml
随后您应该能够获得结果
kubectl顶级节点
和
kubectl get --raw“ /apis/metrics.k8s.io/v1beta1/nodes”
答案 1 :(得分:3)
需要为指标服务器添加标记:
--kubelet-insecure-tls=true
--kubelet-port={YOU_KUBELET_PORT}
--kubelet-preferred-address-types=InternalIP
--v=5
--logtostderr
答案 2 :(得分:0)
出现这些问题是因为您的群集中没有启用度量服务器
仅当cluser上安装了度量标准服务器时,top命令才会运行
从git下载Kubernetes API中的指标服务器
步骤:1 git clone https://github.com/kubernetes-incubator/metrics-server.git
步骤:2 cd metrics-server/
步骤:3 部署
Kubernetes 1.7
kubectl create -f deploy/1.7/
Kubernetes 1.8
kubectl create -f deploy/1.8+/
Setp:4 检查度量标准服务器容器的状态
kubectl get po -n kube-system |grep metrics
第5步: 现在您的最高命令将运行
kubectl top pod --all-namespaces
答案 3 :(得分:0)
编辑metrics-server的部署,并将以下内容添加到其容器的参数中。
--kubelet-insecure-tls
--kubelet-preferred-address-types=InternalIP
例如,
kind: Deployment
metadata:
name: metrics-server
...
spec:
template:
spec:
...
containers:
- name: metrics-server
image: k8s.gcr.io/metrics-server-amd64:v0.3.6
args:
- --kubelet-insecure-tls
- --kubelet-preferred-address-types=InternalIP