gpt4 book ai didi

java - 如何使用 java io.fabric8 kubernetes-client 库获取节点 CPU% 和 MEMORY% 值

转载 作者:行者123 更新时间:2023-12-02 18:44:11 24 4
gpt4 key购买 nike

kubectl 顶级节点
NAME CPU(核心) CPU% MEMORY(字节) MEMORY%

gsdjsgfhdsgfz-12345665-jisj000000 934m 24% 10439Mi 82%
gsdjsgfhdsgfz-12345665-jisj000001 717m 18% 9132Mi 72%
gsdjsgfhdsgfz-12345665-jisj000002 1099m 28% 7614Mi 60%

如何使用 java io.fabric8 kubernetes-client 库获取 CPU% 和 MEMORY% 值。

try (KubernetesClient k8s = new DefaultKubernetesClient()) {

NodeMetricsList nodeMetricsList = k8s.top().nodes().metrics();
for (NodeMetrics nodeMetrics : nodeMetricsList.getItems()) {
logger.info("{} {} {}", nodeMetrics.getMetadata().getName(),
nodeMetrics.getUsage().get("cpu"),
nodeMetrics.getUsage().get("memory"));
}

得到的输出是:-
节点名称
中央处理器:-1094942089n
内存:-7830672Ki

如何取百分比值?

最佳答案

我最近不得不实现这个相同的功能,不幸的是我没有找到一种方法来仅通过单独使用 top() API 来获取百分比,我不得不执行两个调用,一个是nodes() 以检索总容量,另一个到 top() 以检索已用容量。然后这只是计算百分比的问题。

一段工作代码:

public static void main(String[] args) {
KubernetesClient kubernetesClient = new DefaultKubernetesClient();
Map<String, Node> nodeMap = kubernetesClient.nodes().list().getItems()
.stream()
.collect(Collectors.toMap(node -> node.getMetadata().getName(), Function.identity()));
List<NodeUsage> usageList = kubernetesClient.top().nodes().metrics().getItems()
.stream()
.map(metric -> new NodeUsage(nodeMap.get(metric.getMetadata().getName()), metric.getUsage()))
.collect(Collectors.toList());
System.out.println(usageList);
}

private static class NodeUsage {
private final Node node;
private final BigDecimal cpuPercentage;
private final BigDecimal memoryPercentage;

private NodeUsage(Node node, Map<String, Quantity> used) {
this.node = node;
cpuPercentage = calculateUsage(used.get("cpu"), node.getStatus().getAllocatable().get("cpu"));
memoryPercentage = calculateUsage(used.get("memory"), node.getStatus().getAllocatable().get("memory"));
}

private static BigDecimal calculateUsage(Quantity used, Quantity total) {
return Quantity.getAmountInBytes(used)
.divide(Quantity.getAmountInBytes(total), 2, RoundingMode.FLOOR)
.multiply(BigDecimal.valueOf(100));
}

public Node getNode() {
return node;
}

public BigDecimal getCpuPercentage() {
return cpuPercentage;
}

public BigDecimal getMemoryPercentage() {
return memoryPercentage;
}
}

关于java - 如何使用 java io.fabric8 kubernetes-client 库获取节点 CPU% 和 MEMORY% 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67673662/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com