12.docker入门到精通—容器监控-CIG

Docker 容器监控之 CAdvisor+InfluxDB+Granfana

1.原生命令

问题:

通过 docker stats 命令可以很方便的看到当前宿主机上所有容器的 CPU,内存以及网络流量等数据,一般小公司够用了。。。。

但是,docker stats 统计结果只能是当前宿主机的全部容器,数据资料是实时的,没有地方存储、没有健康指标过线预警等功能.

2.是什么?

容器监控 3 剑客:CAdvisor 监控收集+InfluxDB 存储数据+Granfana 展示图表

3. compose 容器编排cig

3.1 新建目录

mkdir /mydocker/cig
cd /mydocker/cig

3.2 新建 3 件套 (docker-compose.ymlCAdvisor+InfluxDB+Granfana) 的组合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

解释说明:

version: '3.1'                #必须是3.0以上才能运行docker-compose
 
volumes:
  grafana_data: {}            #实现了grafana数据的挂载
 
services:                    #表示我们要启动的服务,即要docker run的内容,多个实例服务
 influxdb:                    
  image: tutum/influxdb:0.9
  restart: always
  environment:
    -PRE_CREATE_DB=cadvisor    #预先创建一个数据库,创建一个数据库一样
  ports:
    -"8083:8083"        #对外是8083
    -"8086:8086"        #内部即8086
  volumes:
    - ./data/influxdb:/data    #B 从A-B即influxdb服务,拉取的镜像,安装的环境,暴露的端口,下面的cadvisor,grafana都是一样的
 
 cadvisor:
  image: google/cadvisor
  links:
    - influxdb:influxsrv
  command: 
  -storage_driver=influxdb -storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086 #这就是相当于mysql选择的那个驱动
  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                            #因为有restart,所以如影随形,随着docker启动,就启动
  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
    #千言万语一句话,全部由docker-compose一键部署

3.3 检查配置

docker compose config -q# 检查配置,有问题才有输出

3.4 启动 docker-compose 文件

  docker compose up -d  后台启动

3.5 查看三个服务容器是否启动

docker ps

3.6 测试

3.6.1 浏览 cAdvisor 收集服务,http://192.168.3.15:8080/

cadvisor 也有基础的图形展现功能,这里主要用它来作数据采集(收集实时数据)

3.6.2 浏览 influxdb 存储服务,http://192.168.3.15:8083/
3.6.3 浏览 grafana 展现服务,http://192.168.3.15:3000/

默认帐户密码(admin/admin)

配置步骤:

1.配置数据源

2.选择 influxdb 数据源

2.配置面板panel

猜你喜欢

转载自blog.csdn.net/weixin_54514751/article/details/129683753