今天准备开始研究研究当前非常流行的Grafana+Influxdb监控系统,两者都是非常轻量级的应用但是功能却异常强大,可以说Grafana在作图显示方面真的毫不逊色与Cacti。

组件介绍

cAdvisor

  开源软件cAdvisor(Container Advisor)是用于监控容器运行状态的利器之一,该项目主页为https://github.com/google/cadvisor,它被用于多个与docker相关的开源项目中。实际上在Kubernetes系统中,cAdvisor已经被默认集成到了kubelet组件内。cAdvisor提供了web界面可供浏览器访问,在接下来的环境中我们会部署CAdvisor来收集数据信息。

Influxdb

  说到Grafana就不得不提到Influxdb数据库,Influxdb是用Go语言编写的一个开源的分布式时序、事件和指标数据库,不需要外部依赖,该项目的主页为https://www.influxdata.com。

它有三大特性:

  • 时序性(Time Series):与时间相关的函数的灵活使用(诸如最大、最小、求和等)。
  • 度量(Metrics):对实时大量数据进行计算。
  • 事件(Event):支持任意的事件数据,换句话说,任意事件的数据我们都可以做操作。

同时,它还有以下几大特点:

  • schemaless(无结构),可以是任意数量的列;
  • min, max, sum, count, mean, median 一系列函数,方便统计;
  • Native HTTP API, 内置http支持,使用http读写;
  • Powerful Query Language 类似sql;
  • Built-in Explorer 自带管理工具。

Grafana

  Grafana是一个可视化面板(Dashboard),有着非常漂亮的图表和布局展示,功能齐全的度量仪表盘和图形编辑器,支持Graphite、zabbix、InfluxDB、Prometheus和OpenTSDB作为数据源。Grafana主要特性:灵活丰富的图形化选项;可以混合多种风格;支持白天和夜间模式;多个数据源。其项目官方地址为https://grafana.com。

环境准备

创建Influxdb容器,并配置数据库信息。

1.下载influxdb容器。

docker search influxdb

  1. INDEX NAME DESCRIPTION STARS OFFICIAL AUTOMATED
  2. docker.io docker.io/influxdb InfluxDB is an open source time series dat... 481 [OK]
  3. docker.io docker.io/tutum/influxdb InfluxDB image - listens in port 8083 (web... 219 [OK]
  4. docker.io docker.io/telegraf Telegraf is an agent for collecting metric... 156 [OK]
  5. docker.io docker.io/chronograf Chronograf is a visualization tool for tim... 85 [OK]

docker pull docker.io/influxdb

2.运行influxdb容器。

docker run -d -p 8086:8086 --name influxdb docker.io/influxdb

  • -d:以后台进程的形式运行容器。
  • -p:进行端口映射。

  Influxdb在0.13版本以后就已经关闭了web管理界面,但是目前在国内查到的文档大多是时间比较久的文档,所以配置时大多存在web界面的配置,实际上在1.2以后的版本中web管理界面就已经被删除了,所以我们这里做的端口映射只做了一个。

3.进入容器配置所需数据库以及账户信息。

docker ps

  1. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  2. 404c10bd3531 docker.io/influxdb "/entrypoint.sh in..." 22 minutes ago Up 21 minutes 0.0.0.0:8086->8086/tcp influxdb

docker exec -it 404 /bin/bash

influx

  1. Connected to http://localhost:8086 version 1.5.3
  2. InfluxDB shell version: 1.5.3

  在我们登录到Influxdb中可以显示出我们当前Influxdb数据库的版本信息。

create database cadvisor

use cadvisor

CREATE USER "root" WITH PASSWORD '123456' WITH ALL PRIVILEGES

4.退出数据库在界面进行登录测试。

influx -username root -password 123456 -database cadvisor

  我们首先创建了为Grafana提供数据的数据库名称并为此数据库创建了一个账户及密码。

创建cAdvisor容器。

1.下载cAdvisor镜像。

docker pull docker.io/google/cadvisor

2.运行cAdvisor容器。

运行前首先要查看influxdb的ip地址,或者直接使用本机映射的地址,以便我们启动时的连接。

docker inspect --format '{{ .NetworkSettings.IPAddress }}' 404

  1. 172.17.0.2
  1. sudo docker run \
  2. --volume=/:/rootfs:ro \
  3. --volume=/var/run:/var/run:rw \
  4. --volume=/sys:/sys:ro \
  5. --volume=/var/lib/docker/:/var/lib/docker:ro \
  6. --volume=/dev/disk/:/dev/disk:ro \
  7. --publish=8080:8080 \
  8. --detach=true \
  9. --name=cadvisor \
  10. --privileged=true \
  11. google/cadvisor:latest \
  12. -storage_driver=influxdb \
  13. -storage_driver_db=cadvisor \
  14. -storage_driver_user=root \
  15. -storage_driver_password=123456 \
  16. -storage_driver_host=172.17.0.2:8086

  以上创建命令可以查看cAdvisor官网,需要注意的是,我们要为cAdvisor提供连接Influxdb的配置信息,使用官网提供的配置方法创建cAdvisor时会有以下报错需要注意:

  1. F0606 02:09:21.619637 1 cadvisor.go:156] Failed to start container manager: open /sys/fs/cgroup/cpuset: permission denied

解决办法:(创建容器时添加上此选项)

  1. --privileged=true \

3.登录web界面,查看cAdvisor展示数据。

4.登录influxdb查看cAdvisor是否将数据推送到influxdb。

use cadvisor

show measurements

  1. name: measurements
  2. name
  3. ----
  4. cpu_usage_per_cpu
  5. cpu_usage_system
  6. cpu_usage_total
  7. cpu_usage_user
  8. fs_limit
  9. fs_usage
  10. load_average
  11. memory_usage
  12. memory_working_set
  13. rx_bytes
  14. rx_errors
  15. tx_bytes
  16. tx_errors

  至此,我们已经可以确认cAdvisor已经收集了数据并存储至Influxdb中,接下来我们就可以创建Grafana用来展示我们当前的数据了。

创建Grafana容器并配置Grafana展示数据。

1.下载Grafana镜像。

docker search grafana

  1. INDEX NAME DESCRIPTION STARS OFFICIAL AUTOMATED
  2. docker.io docker.io/grafana/grafana The official Grafana docker container 761
  3. docker.io docker.io/kamon/grafana_graphite All in one image running StatsD, Graphite ... 145
  4. docker.io docker.io/monitoringartist/grafana-xxl Dockerized Grafana 5.x/4.x/3.x with all pr... 61 [OK]
  5. docker.io docker.io/tutum/grafana Grafana dashboard for InfluxDB. Please set... 56 [OK]
  6. docker.io docker.io/samuelebistoletti/docker-statsd-influxdb-grafana Docker Image with Telegraf (StatsD), Influ... 50

docker pull docker.io/grafana/grafana

2.创建Grafana容器。

docker run -d --name grafana -p 3000:3000 docker.io/grafana/grafana

3.登录web界面配置Grafana。

  Grafana默认的用户名密码为admin

1.修改默认用户密码。

2.将Influxdb数据源添加入Grafana。



3.创建新的Dashbord。

4.接下来就是更详细的配置项等待我们配置。

数据展示:

使用cAdvisor+Influxdb+Grafana监控系统的更多相关文章

  1. cAdvisor+InfluxDB+Grafana 监控Docker

    容器的监控方案其实有很多,有docker自身的docker stats命令.有Scout.有Data Dog等等,本文主要和大家分享一下比较经典的容器开源监控方案组合:cAdvisor+InfluxD ...

  2. Collectd+InfluxDB+Grafana监控系统搭建

    环境配置 节点 配置 类型 操作系统 Sched 2G 2CPU 50GB ens3=>192.168.200.11 KVM虚拟机 CentOS 7 Nova 4G 2CPU 50GB ens3 ...

  3. 7、Docker监控方案(cAdvisor+InfluxDB+Grafana)

    一.组件介绍 我们采用现在比较流行的cAdvisor+InfluxDB+Grafana组合进行Docker监控. 1.cAdvisor(数据采集) 开源软件cAdvisor(Container Adv ...

  4. docker监控方案实践(cadvisor+influxdb+grafana)

    一.概要 1.1 背景 虚拟化技术如今已经非常热门,如果你不知道什么是虚拟化,那你应该了解虚拟机.虚拟化技术如同虚拟机一样,用于将某些硬件通过软件方式实现"复制",虚拟出" ...

  5. docker容器监控:cadvisor+influxdb+grafana

    cadvisor+influxdb+grafana可以实现容器信息获取.存储.显示等容器监控功能,是目前流行的docker监控开源方案. 方案介绍 cadvisor Google开源的用于监控基础设施 ...

  6. cAdvisor+Prometheus+Grafana监控docker

    cAdvisor+Prometheus+Grafana监控docker 一.cAdvisor(需要监控的主机都要安装) 官方地址:https://github.com/google/cadvisor ...

  7. (原)ubuntu下cadvisor+influxdb+grafana+supervisord监控主机和docker的containers

    ubuntu下cadvisor+influxdb+grafana+supervisord监控主机和docker的containers(运行在主机上) 适用于类ubuntu系统.amd64. 1. in ...

  8. 使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况

    使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况 前言 本文在Debian9下采用Docker的方式安装Telegraf + Influxdb + ...

  9. WIndows下使用Grafana+InfluxDB打造监控系统

     前言 对于一个运维DBA来说,了解数据库的TPS.QPS很有必要(QPS:每秒查询数,即对数据库每秒的DML的操作数:TPS:每秒事物处理,即对数据库每秒DDL操作数),通过了解他们,可以掌握一个实 ...

随机推荐

  1. webpack的三种用法

    1.直接命令行使用. 2.node.js API的使用方式. 3.webpack / webpack--config webpack. dev.config.js //根目录创建 webpack.co ...

  2. Java数组的声明和遍历

    Java 数组 数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同. Java 语言中提供的数组是用来存储固定大小的同类型元素. 你可以声明一个数组变量,如 n ...

  3. JS & JQuery 动态处理select option

    原文 出处http://www.51xuediannao.com/html+css/htmlcssjq/cssbuhuanhang.html 今天你问了我一个关于在<select>里动态添 ...

  4. Emacs中的拼写检查

    无论是在Emacs中写英文日记(diary).Org mode笔记,还是撰写程序的注释和文档,拼写检查都是一项提高工作效率.保证成果品质的必不可缺的工具.拼写检查对于常见的文字处理软件(如Word.L ...

  5. 咸鱼入门到放弃11--Servlet+JSP+JavaBean开发模式

    本篇搬运了大佬blog:https://www.cnblogs.com/xdp-gacl/p/3902537.html 一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servle ...

  6. pwn学习之二

    刚刚开始学习pwn,记录一下自己学习的过程. 今天get了第二道pwn题目的解答,做的题目是2017年TSCTF的easy fsb,通过这道题了解了一种漏洞和使用该漏洞获取shell的方法:即格式化字 ...

  7. 部分手机浏览器存在将ajax请求当成广告过滤的情况,及解决方案

    我们发现h5页面在某些浏览器请求不到数据,经过排查,是浏览器的广告拦截模块搞的鬼. 通过删减参数,发现adtype和adnum参数去掉后,接口可以正常请求,开始以为是官方拦截关键词带有ad的参数,后来 ...

  8. maya cmds pymel selectType() 选择类型切换

    maya cmds pymel selectType() 选择类型切换 import maya.cmds as cmds cmds.selectType( polymeshFace = True ) ...

  9. java位移运算符2 转

    https://blog.csdn.net/xxx134617/article/details/7454774 java中int类型占4个字节,二进制用补码表示: 3的二进制表示: 00000000 ...

  10. webpack问题列表及解决方案

    1.提升webpack打包速度 2.cssloader顺序有先后 3.如何正确引用图片 4.打包后访问不到json文件 5.打包后如何访问项目 6.打包后的文件 7.为什么执行webpack,就可以打 ...