【K8S问题系列 | 10】在K8S集群怎么查看各个pod占用的资源大小?【已解决】

要查看 Kubernetes 集群中各个 Pod 占用的资源大小(包括 CPU 和内存),可以使用以下几种方法:

1. 使用 kubectl top 命令

kubectl top 命令可以快速查看当前 Pod 的 CPU 和内存使用情况。需要确保已安装并配置了 Metrics Server。

查看所有 Pod 的资源使用情况

bash 复制代码
kubectl top pods --all-namespaces

示例输出

plaintext 复制代码
NAMESPACE     NAME           CPU(cores)   MEMORY(bytes)
default       my-app-1      500m         128Mi
default       my-app-2      300m         256Mi
kube-system    kube-dns      100m         64Mi

说明

  • CPU(cores): 显示 Pod 当前使用的 CPU 核心数。
  • MEMORY(bytes): 显示 Pod 当前使用的内存量。

2. 使用 kubectl describe 命令

kubectl describe 命令可用于查看特定 Pod 的详细信息,包括资源请求和限制。

查看特定 Pod 的详细信息

bash 复制代码
kubectl describe pod <pod-name> -n <namespace>

示例输出

plaintext 复制代码
Name:           my-app-1
Namespace:      default
Priority:       0
Node:          node-1/192.168.1.1
Start Time:    Mon, 01 Nov 2023 10:00:00 +0000
Labels:         app=my-app
Annotations:    <none>

Status:         Running
IP:             10.244.1.2
Containers:
  app-container:
    Container ID:   docker://abcdef123456
    Image:          my-app-image:latest
    Image ID:       docker-pullable://my-app-image@sha256:...
    Port:           8080/TCP
    Host Port:      0/TCP
    State:          Running
      Started:      Mon, 01 Nov 2023 10:00:01 +0000
    Ready:          True
    Restart Count:  0
    Limits:
      cpu:     1
      memory:  1Gi
    Requests:
      cpu:     500m
      memory:  256Mi

说明

  • LimitsRequests: 表示 Pod 对 CPU 和内存的请求和限制。虽然这并不显示实际使用情况,但可以帮助理解 Pod 的资源配置。

3. 使用 Prometheus 和 Grafana

如果您已经配置了 Prometheus 和 Grafana,可以在 Grafana 中查看 Pod 的资源使用情况,并创建可视化仪表板。

在 Grafana 中查看

  1. 登录 Grafana。
  2. 创建一个新的仪表板或查看现有的仪表板。
  3. 使用 Prometheus 查询,查看 Pod 的 CPU 和内存使用情况。
示例 Prometheus 查询
  • 查询所有 Pod 的 CPU 使用情况:

    plaintext 复制代码
    sum(rate(container_cpu_usage_seconds_total{container_name!="POD"}[5m])) by (pod_name)
  • 查询所有 Pod 的内存使用情况:

    plaintext 复制代码
    sum(container_memory_usage_bytes{container_name!="POD"}) by (pod_name)

4. 使用 Kube Metrics API

您还可以直接访问 Kubernetes Metrics API(如果已启用 Metrics Server),以获取 Pod 的 CPU 和内存使用情况。

示例命令

bash 复制代码
kubectl get --raw "/apis/metrics.k8s.io/v1beta1/pods" | jq .

说明

  • 这个命令将返回集群中所有 Pod 的 CPU 和内存使用情况,返回的数据格式为 JSON。

总结

通过以上方法,您可以轻松查看 Kubernetes 集群中各个 Pod 的资源使用情况,包括 CPU 和内存。如果需要更深入的监控和可视化,建议结合使用 Prometheus 和 Grafana。

相关推荐
man20171 小时前
【2024最新】基于springboot+vue的闲一品交易平台lw+ppt
vue.js·spring boot·后端
hlsd#1 小时前
关于 SpringBoot 时间处理的总结
java·spring boot·后端
路在脚下@1 小时前
Spring Boot 的核心原理和工作机制
java·spring boot·后端
幸运小圣1 小时前
Vue3 -- 项目配置之stylelint【企业级项目配置保姆级教程3】
开发语言·后端·rust
前端SkyRain2 小时前
后端Node学习项目-用户管理-增删改查
后端·学习·node.js
提笔惊蚂蚁2 小时前
结构化(经典)软件开发方法: 需求分析阶段+设计阶段
后端·学习·需求分析
老猿讲编程3 小时前
Rust编写的贪吃蛇小游戏源代码解读
开发语言·后端·rust
黄小耶@3 小时前
python如何使用Rabbitmq
分布式·后端·python·rabbitmq
宅小海4 小时前
Scala-List列表
开发语言·后端·scala
蔚一5 小时前
Javaweb—Ajax与jQuery请求
前端·javascript·后端·ajax·jquery