docker-CAdvisor+InfluxDB+Granfana容器監(jiān)控

一、前期準(zhǔn)備:在Linux服務(wù)器上安裝好docker,docker-compose

常用指令

列出運(yùn)行中容器
docker ps 
列出所有容器,包括未運(yùn)行的。
docker ps -a
進(jìn)入容器
docker exec -it <container_id> /bin/bash
停止容器
docker stop  <container_id>
后臺運(yùn)行docker-compose (第一次啟動最好不用-d,因?yàn)榭赡苡袌箦e信息)
docker-compose up -d

二、使用docker安裝influxdb

docker run -d --name influxdb -p 8086:8086  -v /data/influxdb:/var/lib/influxdb  --hostname=influxdb  influxdb
  1. 安裝成功應(yīng)顯示
Unable to find image 'influxdb:latest' locally
latest: Pulling from library/influxdb
07471e81507f: Pull complete
c6cef1aa2170: Pull complete
13a51f13be8e: Pull complete
b6f021d1bd1c: Pull complete
ecf4e96afd5f: Pull complete
012b872e0ffa: Pull complete
fdfd321c83b8: Pull complete
2b9d42a4857a: Pull complete
3b93d6fb4c2d: Pull complete
Digest: sha256:ed884c6895724a4677de78e84df0246ced5d898216cd6d69332bebca2da22fd6  --hostname=influxdb  influxdb
Status: Downloaded newer image for influxdb:latest
f47c40a3ddbf444ddf873xxxxxxxxxxxxxxxxxxx47a33a427a3f03015894ced4

2.瀏覽器輸入ip:8086即可看到一下頁面


influxdb

2.1、 創(chuàng)建root用戶和test用戶(用于后期配置granfana)。
可以在頁面上創(chuàng)建,也可以通過命令
docker exec -it <container_id> /bin/bash
我這里容器名字就叫influxdb,所以運(yùn)行一下命令即可進(jìn)入docker里面

docker exec -it influxdb bin/bash 

create database "influxdb"
create user "root" with password 'rootroot' with all previleges
  1. cadvisor
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 --volume=/cgroup:/cgroup:ro \
--publish=8080:8080 --detach=true --privileged=true --name=cadvisor \
google/cadvisor:latest \
-storage_driver=influxdb-storage_driver_host=influxdb:8086 \
-storage_driver_db=cadvisor \
-storage_driver_user=root \
-storage_driver_password=root 

3.grafana

docker run -d -p 3000:3000 \
-v /data/grafana:/varlib/grafana \
--link=influxdb:influxdb \
--name grafana \
grafana/grafana 

三、使用docker-compoes安裝CAdvisor+InfluxDB+Granfana

創(chuàng)建好docker-compose.yaml配置如下

version: '3.1'

volumes:
  grafana_data: {}

services:
 influxdb:
  image: tutum/influxdb:0.9
  #image: tutum/influxdb
  #image: influxdb
  restart: always
  #user: 
  environment:
    - PRE_CREATE_DB=cadvisor
  ports:
    - "8083:8083"
    - "8086:8086"
  expose:
    - "8090"
    - "8099"
  volumes:
    - ./data/influxdb:/data

 cadvisor:
  #image: google/cadvisor:v0.29.0
  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:
  #image: grafana/grafana:2.6.0
  user: "104"
  image: grafana/grafana
  user: "104"
  #user: "472"
  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

驗(yàn)證配置是否正確
docker-compose config 
啟動安裝容器
docker-compose up
看到
 write to index of partition 1 took 5.399166ms
證明成功了
新開一個頁面,運(yùn)行
docker ps -a
應(yīng)該可以看到
CONTAINER ID   IMAGE                COMMAND                  CREATED          STATUS                      PORTS                                                                                                      NAMES
81984542671a   google/cadvisor      "/usr/bin/cadvisor -…"   8 seconds ago    Up 7 seconds                0.0.0.0:8080->8080/tcp, :::8080->8080/tcp                                                                  cadivsor-cadvisor-1
713ae988d3f4   grafana/grafana      "/run.sh"                8 seconds ago    Up 7 seconds                0.0.0.0:3000->3000/tcp, :::3000->3000/tcp                                                                  cadivsor-grafana-1
c6a712f78e8a   tutum/influxdb:0.9   "/run.sh"                8 seconds ago    Up 7 seconds                0.0.0.0:8083->8083/tcp, :::8083->8083/tcp, 8090/tcp, 0.0.0.0:8086->8086/tcp, :::8086->8086/tcp, 8099/tcp   cadivsor-influxdb-1

四、剩下的就是最麻煩的配置grafana界面了

請參考這篇文章:https://www.cnblogs.com/chanshuyi/p/03_grafana_chart_quick_start.html

最后附送幾個查詢的sql

上傳下載流量(記得分開兩個query寫):
SELECT derivative(mean("value"), 1s) FROM "rx_bytes" WHERE ("container_name" = '/') AND $timeFilter GROUP BY time(1m) fill(null) 
SELECT derivative(mean("value"), 1s) FROM "tx_bytes" WHERE ("container_name" = '/') AND $timeFilter GROUP BY time(1m) fill(null) 

磁盤使用情況單位GB
SELECT mean("value") FROM "fs_usage" WHERE ("container_name" = '/') AND ("device" = '/dev/vda1') AND $timeFilter GROUP BY time($__interval) fill(null)

cpu占用率(16000000000 因?yàn)槲沂?6核的cpu):
SELECT derivative(mean("value"), 1s)  / 16000000000 FROM "cpu_usage_total" WHERE ("container_name" = '/') AND $timeFilter GROUP BY time($__interval) fill(previous)

內(nèi)存使用率百分比(32805847040 表示大概32G內(nèi)存):
SELECT mean("value")  / 32805847040 FROM "memory_usage" WHERE ("container_name" = '/') AND $timeFilter GROUP BY time($__interval) fill(null)

最后poke一張效果圖

效果圖

當(dāng)然你也可以在Grafana官網(wǎng) -Grafana官網(wǎng) - Dashboards 模塊 找到你喜歡的現(xiàn)成模板。但能不能用就不一定了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容