prometheus+cadvisor监控docker

news/2024/5/19 0:21:46 标签: docker, prometheus, 容器

官方解释 cAdvisor(ContainerAdvisor)为容器用户提供了对其运行容器的资源使用和性能特性的了解。它是一个正在运行的守护程序,用于收集、聚合、处理和导出有关正在运行的容器的信息。具体来说,它为每个容器保存资源隔离参数、历史资源使用情况、完整历史资源使用的直方图和网络统计信息。该数据按容器和机器范围导出。

说白了其实和一般监控的agent类似,就是将容器内部的监控指标持久化存储然后web ui界面展示,结合prometheus+grafana更好的汇聚监控指标

docker_3">1. docker部署

[root@zabbix cadvisor]# cat docker-cadvisor.yml 
version: "3.5"
services:
  cadvisor:
    image: harbor.od.com/prometheus/cadvisor:latest
    container_name: cadvisor
    volumes:
      - /:/rootfs:ro
      - /var/run:/var/run:ro
      - /sys:/sys:ro
      - /var/lib/docker/:/var/lib/docker:ro
      - /dev/disk/:/dev/disk:ro
    ports:
      - 8088:8080
      
[root@zabbix cadvisor]# docker-compose -f docker-cadvisor.yml up -d    
  1. 镜像地址 ,启动后访问http://ip:8088即可看到界面,包含内存、cpu、network、Filesystem等监控信息,
    在这里插入图片描述

  2. 查看不同容器数据修改访问后缀即可,比如查看jenkins访问地址为http://ip:8080/docker/jenkins,其他依次类推,web界面不是很方便,因为都是容器形成的字符串不好识别

  3. Cgroups 的工作目录为/sys/fs/cgroup,Cgroups包含很多子系统,可以用来对不同的资源进行限制。例如对CPU、内存、PID、磁盘 IO等资源进行限制和监控

  4. CPU、内存、网络等资源使用情况信息,是从 cgroup 文件系统中读取相应的文件,
    /sys/fs/cgroup/cpuacct/docker/[container_id]/cpuacct.usage、
    /sys/fs/cgroup/memory/docker/[container_id]/memory.usage_in_bytes、
    /sys/fs/cgroup/net_cls,net_prio/docker/[container_id]/net_cls.classid 等。
    磁盘 I/O、网络 I/O 等性能指标信息,则是从 proc 文件系统中的相应文件读取,例如 /proc/[container_pid]/io、/proc/[container_pid]/net/dev 等。

在这里插入图片描述
1635495936byte换算下来也就是1.635495936GB也接近如下docker stats所展示的
在这里插入图片描述
web页面获取到的和stats获取到的都是接近的数值
在这里插入图片描述

prometheus_39">2. 配置prometheus

prometheus.yml中添加cadvisor信息

scrape_configs:
  - job_name: 'cadvisor'
    scrape_interval: 15s
    static_configs:
    - targets: ['10.1.74.21:8088']

重新加载prometheus

1. 重启
docker restart prometheus

2. 重新加载配置文件
curl -X POST http://localhost:9090/-/reload

访问http://localhost:9090/targets即可查看对应的端点是否连通正常
在这里插入图片描述


http://www.niftyadmin.cn/n/103356.html

相关文章

只需四步,手把手教你打造专属数字人

伴随ChatGPT的问世,在技术与商业运作上都日渐发展成熟的数字人产业正持续升温。去年9月,北京市发布了国内首个数字人产业专项支持政策,提出将依托国家文化专网将数字人纳入文化数据服务平台。以数字人、ChatGPT为代表的互联网3.0创新应用产业…

接收arp请求并发送回应的实例

本文简单介绍了arp协议,用一个实例查看收到的ARP请求,并对该请求发出ARP回应,实例有完整的源代码,使用C语言在Linux下实现,代码中有详细的注释。 1. ARP协议 ARP(Address Resolution Protocol),地址解析协议;在局域网上通过IP地址获取物理地址MAC的协议,该协议工作在数…

【说说redis的缓存穿透、缓存击穿、缓存雪崩以及解决方案】

Redis是一种常用的缓存技术,但在实际应用中,可能会遇到一些缓存问题,包括缓存穿透、缓存击穿和缓存雪崩等。下面是对这些问题的解释及解决方案: 缓存穿透 缓存穿透指的是当查询一个不存在的key时,由于缓存中不存在该…

Nginx 使用笔记

反向代理负载均衡动静分离 架构的核心思想——分层 VPN 正向代理 Nginx 内存占用小,支持5万的高并发 启动需要英文目录 linux 中 解压执行 configure 文件未报错 执行 make 、make installwhereis nginx 找到安装目录sbin 下可启动 nginx;conf 下可配…

【考研408】算法与数据结构笔记

文章目录绪论数据结构的基本概念算法和算法评价线性表线性表的定义和基本操作线性表的顺序表示线性表的链式表示栈和队列栈基本操作栈的顺序存储结构栈的链式存储队列队列常见的基本操作队列的顺序存储结构队列的链式存储结构双端队列栈和队列的应用栈在括号匹配中的应用栈在表…

SAP 深入谈谈银企直连

一、发展历史 2011年,在SAP ECC6 Ehp5中,通过功能增强FIN_LOC_CI_16发布中国版的银企直连(Electronic payment integration with Chinese 简称EPIC)。 后续2年左右时间内,SAP先后在ECC Ehp6的多个SP(支持…

7、算法MATLAB ---(运算符)(语句)

运算符&语句1.关系运算符2.逻辑运算符3. if...else 控制语句4. for循环5. While循环6.控制循环退出的关键字6.1 Break6.2 Continue6.3 Return1.关系运算符 ">"大于 ">"大于等于 "<"小于 "<"小于等于 ""等于…

hive解析json字段

1、get_json_object 格式&#xff1a;get_json_object(待解析的字段&#xff0c;‘.$要取的属性’) eg&#xff1a;待解析的字符串&#xff1a; {“code”:“0001”,“dept”:“市场部”}&#xff0c;分别获取code 和dept select get_json_object({"code":"…