首页 > 解决方案 > 使用 Java 客户端库从 Pod 访问 Kubernetes Api

问题描述

我目前使用客户端 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");

标签: kuberneteskubernetes-apiserverkubernetes-metrics

解决方案


ApiClient您可以使用直接拨打电话。像这样的东西。

ApiClient client = Config.defaultClient();
ApiResponse<Object> result = client.execute(client.buildCall(...));

推荐阅读