一、问题引入
1、命令说明
docker stats : 查看当前宿主机上所有容器的 CPU、内存、网络流量等。
2、不足之处
docker stats : 统计结果只能是当前宿主机的全部容器,数据资料是实时的,没有地方存储、
没有健康指标过线预警等功能。
二、概念
2.1 CAdvisor
2.2 InfluxDB
2.3 Granfana
2.4 小总结
CAdvisor监控收集+InfluxDB存储数据+Granfana展示图表
类似于ELK 收集+存储+展示
logstash收集日志+es存储日志+kibana展示日志
三、compose容器编排,安装启动三个应用
3.1 新建目录
mkdir /home/dongzhigang/cig
mkdir /home/dongzhigang/cig/data
3.2 编写docker-compose.yml
cd /home/dongzhigang/cig
vim docker-compose.yml
version: '3.1'
volumes:
grafana_data: {}
services:
influxdb:
image: tutum/influxdb:0.9
restart: always
environment:
- PRE_CREATE_DB=cadvisor
ports:
- "8083:8083"
- "8086:8086"
volumes:
- ./data/influxdb:/data
cadvisor:
image: google/cadvisor
links:
- influxdb:influxsrv
command: -storage_driver=influxdb -storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086
restart: always
ports:
- "8080:8080"
volumes:
- /:/rootfs:ro
- /var/run:/var/run:rw
- /sys:/sys:ro
- /var/lib/docker/:/var/lib/docker:ro
grafana:
user: "104"
image: grafana/grafana
user: "104"
restart: always
links:
- influxdb:influxsrv
ports:
- "3000:3000"
volumes:
- grafana_data:/var/lib/grafana
environment:
- HTTP_USER=admin
- HTTP_PASS=admin
- INFLUXDB_HOST=influxsrv
- INFLUXDB_PORT=8086
- INFLUXDB_NAME=cadvisor
- INFLUXDB_USER=root
- INFLUXDB_PASS=root
3.3 启动docker-compose文件
docker-compose up
3.4 查看是否启动成功
docker ps
四、界面访问
4.1 cAdvisor收集服务
http://192.168.215.140:8080
第一次访问慢,请稍等。
cadvisor也有基础的图形展现功能,这里主要用它来作数据采集。
4.2 influxdb存储服务
http://192.168.215.140:8083
4.3 grafana展现服务
http://192.168.215.140:3000
第一次默认账号密码: admin/admin
五、配置grafana
5.1配置数据源
5.2 选择influxdb数据源
5.3 influxdb配置细节
5.4 配置面板panel
1、点击+号,create
2、Add an empty panel 添加个空面板
3、点击右上角搜索 Graph
4、选择 Graph (old)
5、配置参数
6、保存