docker服务监控中的cAdvisor详解

 更新时间:2025年05月05日 08:30:44   作者:huangSir-devops  
cAdvisor(Container Advisor)是谷歌开源的一款容器资源监控工具,它可以收集容器的 CPU、内存、磁盘 I/O、网络等资源使用情况的信息,本文给大家介绍docker服务监控中的cAdvisor,感兴趣的朋友一起看看吧

概述

cAdvisor(Container Advisor)是谷歌开源的一款容器资源监控工具,它可以收集容器的 CPU、内存、磁盘 I/O、网络等资源使用情况的信息,并提供了一个直观的 Web 界面来展示这些数据,方便用户快速了解容器的运行状态。

特点

  • 资源监控:能实时监控容器的各项资源使用情况,包括 CPU 使用率、内存使用量、磁盘读写速率、网络带宽等。例如,通过它可以查看某个容器是否占用了过多的 CPU 资源,导致其他容器运行缓慢。

  • 容器拓扑结构展示:可以展示容器之间的关系以及它们与宿主机的关系,使用户清晰地了解容器的部署情况。

  • 历史数据存储与查询:支持将监控数据存储到后端数据库中,如 InfluxDB,以便用户查询历史数据,分析容器资源使用的趋势。

  • 支持多种运行环境:不仅支持 Docker 容器,还能用于其他容器化技术,如 runc、systemd-nspawn 等,具有很强的通用性。

工作原理

cAdvisor 通过收集宿主机和容器的相关信息来实现监控功能。它利用了 Linux 系统的 cgroups(控制组)来获取容器的资源使用数据。cgroups 为每个容器分配了独立的资源限制和统计信息,cAdvisor 通过读取这些信息来了解容器对 CPU、内存、磁盘等资源的使用情况。同时,它还利用了 Linux 的网络协议栈来收集网络相关的统计数据。

部署cAdvisor监控Docker

这里不要使用Google的cadvisor,否则会报

F0501 07:18:47.974792       1 cadvisor.go:146] Failed to create a Container Manager: mountpoint for cpu not found

我这里使用lagoudocker/cadvisor:v0.37.0解决的

# 运行容器
[root@lb ~]# docker run \
  --volume=/:/rootfs:ro \
  --volume=/var/run:/var/run:ro \
  --volume=/sys:/sys:ro \
  --volume=/var/lib/docker/:/var/lib/docker:ro \
  --volume=/dev/disk/:/dev/disk:ro \
  --publish=8080:8080 \
  --detach=true \
  --name=cadvisor \
  --privileged \
  --device=/dev/kmsg \
  lagoudocker/cadvisor:v0.37.0
# 查看
[root@lb ~]# docker ps -a
CONTAINER ID   IMAGE                                 COMMAND                  CREATED          STATUS                            PORTS                                         NAMES
b1d70b85c056   lagoudocker/cadvisor:v0.37.0          "/usr/bin/cadvisor -…"   6 seconds ago    Up 6 seconds (health: starting)   0.0.0.0:8080->8080/tcp, [::]:8080->8080/tcp   cadvisor

直接访问http://10.0.0.10:8080/

到此这篇关于docker服务监控中的cAdvisor详解的文章就介绍到这了,更多相关docker服务监控cAdvisor内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Docker容器搭建Kafka集群的详细过程

    Docker容器搭建Kafka集群的详细过程

    这篇文章主要介绍了Docker容器 Kafka集群的搭建,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • Docker网络配置(桥接网络和自定义网络)自定义网络设置ip方式

    Docker网络配置(桥接网络和自定义网络)自定义网络设置ip方式

    这篇文章主要介绍了Docker网络配置(桥接网络和自定义网络)自定义网络设置ip方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • Docker安装Tomcat、MySQL和Redis的步骤详解

    Docker安装Tomcat、MySQL和Redis的步骤详解

    这篇文章主要介绍了Docker安装Tomcat、MySQL和Redis的步骤详解,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • CentOS下Docker的安装教程详解

    CentOS下Docker的安装教程详解

    今天小编就为大家分享一篇关于CentOS下Docker的安装教程详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • Docker 替换宿主与容器的映射端口和文件路径的操作方法

    Docker 替换宿主与容器的映射端口和文件路径的操作方法

    本文介绍了如何在使用Docker容器化应用程序时,替换和配置端口和文件路径映射,本文给大家介绍的非常详细感兴趣的朋友跟随小编一起看看吧
    2025-01-01
  • Docker 存储管理的几种方式

    Docker 存储管理的几种方式

    本文主要使用三种不同的方式将数据从Docker主机挂载到容器中,分别为卷(volumes),绑定挂载(bind mounts),临时文件系tmpfs,还介绍了数据卷容器、数据卷的备份与恢复,对Docker 存储管理相关知识感兴趣的朋友一起看看吧
    2022-07-07
  • Docker如何进入启动容器

    Docker如何进入启动容器

    本篇文章主要介绍了Docker如何进入启动容器,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • 使用Docker部署Angular项目的方法步骤

    使用Docker部署Angular项目的方法步骤

    这篇文章主要介绍了使用Docker部署Angular项目的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • 替换docker容器中的一个文件的实现

    替换docker容器中的一个文件的实现

    在某些情况下,我们可能确实需要更新容器内的文件,本文主要介绍了替换docker容器中的一个文件的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-06-06
  • Docker 安装 Nginx 并挂载目录的实现示例

    Docker 安装 Nginx 并挂载目录的实现示例

    本文介绍了如何使用Docker拉取Nginx镜像、创建容器,并设置挂载目录,挂载目录用于将容器内配置文件与主机关联,便于直接修改影响容器配置,感兴趣的可以了解一下
    2024-10-10

最新评论