我目前使用客户端 java kubernetes 库从 Kubernetes API 获取指标
<dependency>
<groupId>io.kubernetes</groupId>
<artifactId>client-java</artifactId>
<version>12.0.0</version>
</dependency>
我发现位于此路径https://kubernetes.default.svc/api/v1/nodes/worker02/proxy/metrics/cadvisor下的有关网络和文件系统 I/O 的一些指标非常有趣。
container_network_receive_bytes_total{container="",id="/kubepods/besteffort/podb6bf750b-4501-4082-9a50-3751ff1e4f0f/72f84fc52547c628baeee527a47faa204eadd660ba4cbb94d8889562ff0b7789",image="docker.io/rancher/pause:3.1",interface="eth0",name="72f84fc52547c628baeee527a47faa204eadd660ba4cbb94d8889562ff0b7789",namespace="kube-system",pod="svclb-traefik-2wlkz"} 50398 1618932055188
但是,由于它们采用 prometheus 度量格式,因此库不支持它们。
我后来意识到,使用 http 客户端获取信息并不成功(javax.net.ssl.SSLHandshakeException),因为我没有传递令牌和证书。有没有办法使用 client-java 库来获取 API 的原始答案?
我正在考虑这样的事情,提前谢谢
String apiAnswer = client.getRaw("/api/v1/nodes/worker02/proxy/metrics/cadvisor");