一、前期準(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
- 安裝成功應(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
- 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)成模板。但能不能用就不一定了。