乐闻世界logo
搜索文章和话题

How to calculate containers' cpu usage in kubernetes with prometheus as monitoring?

5 个月前提问
5 个月前修改
浏览次数45

1个答案

1

在Kubernetes环境中,使用Prometheus来监控容器的CPU使用率是一个非常有效的方法。以下是具体的步骤和实践:

1. 安装Prometheus

首先,确保在你的Kubernetes集群中安装Prometheus。你可以通过多种方式来安装,最常用的是使用Helm charts。

使用Helm安装Prometheus:

bash
# 添加Prometheus的Helm仓库 helm repo add prometheus-community https://prometheus-community.github.io/helm-charts # 更新Helm仓库 helm repo update # 安装Prometheus helm install [RELEASE_NAME] prometheus-community/prometheus

这将在你的Kubernetes集群中安装Prometheus并默认配置一些监控目标。

2. 配置Prometheus监控Kubernetes

安装完成后,确保Prometheus配置了正确的监控目标。Prometheus通过Service Discovery机制自动发现Kubernetes中的目标。

配置示例:

yaml
scrape_configs: - job_name: 'kubernetes-pods' kubernetes_sd_configs: - role: pod relabel_configs: - source_labels: [__meta_kubernetes_pod_annotation_prometheus_io_scrape] action: keep regex: true - source_labels: [__meta_kubernetes_pod_annotation_prometheus_io_path] action: replace target_label: __metrics_path__ regex: (.+)

这个配置使Prometheus监控所有标记为 prometheus.io/scrape: true 的Pods。

3. 使用PromQL查询CPU使用率

Prometheus收集数据后,你可以使用PromQL来查询具体的CPU使用率。

查询Pod的CPU使用率:

plaintext
rate(container_cpu_usage_seconds_total{container!="POD",namespace="default"}[5m])

这条PromQL语句计算过去5分钟内,命名空间为default中每个容器的CPU使用率。

4. 使用Grafana展示数据

为了更好的可视化展示和监控,你可以使用Grafana来展示Prometheus收集的数据。Grafana可以连接到Prometheus数据源,并构建图形化的仪表板。

连接Grafana到Prometheus:

在Grafana中添加Prometheus作为数据源,输入Prometheus服务的URL。

创建仪表板显示CPU使用率:

在Grafana中创建新的仪表板,添加图表,设置PromQL查询语句,即可可视化地查看CPU使用情况。

总结

通过上述步骤,你可以在Kubernetes中通过Prometheus有效地监控和查询容器的CPU使用率,结合Grafana可以达到更直观的监控效果。这种方法可以帮助运维团队更好地了解资源使用情况,及时优化和调整资源分配。

2024年7月25日 19:25 回复

你的答案