系列文章目录
第一章 CentOS Docker安装: link
第二章 常用命令: link
第三章 Docker镜像: link
第四章 本地镜像发布到阿里云: link
第五章 本地镜像发布到私有库: link
第六章 容器数据卷: link
第七章 Docker常规安装简介: link
第八章 Docker复杂安装案例: link
第九章 DockerFile解析: link
第十章 Docker微服务实战: link
第十一章 Docker网络: link
第十二章 Docker-compose容器编排: link
第十三章 Docker轻量级可视化工具Portainer: link
第十四章 Docker容器监控之 CAdvisor+InfluxDB+Granfana: link
1 原生命令的问题
1.1 操作
docker stats命令的结果
1.2 问题
通过docker stats命令可以很方便的看到当前宿主机上所有容器的CPU,内存以及网络流量等数据,一般小公司够用了。。。。
但是,
docker stats统计结果只能是当前宿主机的全部容器,数据资料是实时的,没有地方存储、没有健康指标过线预警等功能
1.3 容器监控3剑客
CAdvisor监控收集+InfluxDB存储数据+Granfana展示图表
1.3.1 CAdvisor
1.3.2 InfluxDB
1.3.3 Granfana
1.3.4 总结
2 案例
2.1 新建目录
2.2 新建3件套组合的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
2.3 启动docker-compose文件
docker-compose up
2.4 查看三个服务容器是否启动
2.5 测试
2.5.1 浏览cAdvisor收集服务,http://ip:8080/
2.5.2 浏览influxdb存储服务,http://ip:8083/
2.5.3 浏览grafana展现服务,http://ip:3000
ip+3000端口的方式访问,默认帐户密码(admin/admin)
2.5.3.1 配置步骤
2.5.3.1.1 配置数据源
2.5.3.1.2 选择influxdb数据源
2.5.3.1.3 配置细节
2.5.3.1.4 配置面板panel
1
2
3
4
5
6