我正在使用 Kubernetes 1.7 并运行 hepaster。当我跑步时
kubectl top nodes --heapster-namespace=kube-system
它向我展示了
error: metrics not available yet
我也试过这个
kubectl top nodes --heapster-namespace=kube-system --heapster-service=heapster --heapster-scheme=http --heapster-port=12213
在堆运行时,它会显示以下错误。
Error from server (ServiceUnavailable): the server is currently unable to handle the request (get services http:heapster:12213)
有什么解决错误的线索吗?
这意味着堆未正确配置。
您需要确保堆kube-system
命名空间上运行,并检查/healthz
终结点是否正常:
$ export HEAPSTER_POD=$(kubectl get po -l k8s-app=heapster -n kube-system -o jsonpath='{.items[*].metadata.name}')
$ export HEAPSTER_SERVICE=$(kubectl get service/heapster --namespace=kube-system -o jsonpath="{.spec.clusterIP}")
$ curl -L "http://${HEAPSTER_SERVICE}/healthz"
ok
然后,您可以检查指标 API 是否可用:
$ curl -L "http://${HEAPSTER_SERVICE}/api/v1/model/metrics/"
[
"cpu/usage_rate",
"memory/usage",
"cpu/request",
"cpu/limit",
"memory/request",
"memory/limit"
]
如果未按上述方式返回,请查看容器日志中的错误:
$ kubectl logs -n kube-system ${HEAPSTER_POD} --all-containers
虽然,请记住,Heapster 是一个已弃用的项目,在最近的 Kubernetes 版本中运行它时可能会遇到问题。
请参阅堆弃用时间线:
| Kubernetes Release | Action | Policy/Support | |---------------------|---------------------|----------------------------------------------------------------------------------| | Kubernetes 1.11 | Initial Deprecation | No new features or sinks are added. Bugfixes may be made. | | Kubernetes 1.12 | Setup Removal | The optional to install Heapster via the Kubernetes setup script is removed. | | Kubernetes 1.13 | Removal | No new bugfixes will be made. Move to kubernetes-retired organization. |
从 Kubernetes v1.10 开始,kubectl top
默认依赖于指标服务器。
CHANGELOG-1.10.md:
- 在
kubectl top
命令中支持指标 API。(#56206, @brancz(此 PR 实现了对
kubectl top
命令的支持,以使用 指标服务器作为聚合 API,而不是请求指标 直接从堆。如果metrics.k8s.io
API 未由 apiserver,那么这仍然会回退到之前的行为。
最好使用kubectl
v1.10
或更高版本,因为它从指标服务器获取指标。
但是,请注意kubectl
版本偏差策略:
kubectl
在kube-apiserver
在选择kubectl
版本之前,请检查您的kube-apiserver
版本。