为了账号安全,请及时绑定邮箱和手机立即绑定

使用 Grafana、collectd 和 InfluxDB 打造现代监控系统

标签:
Linux

想打造 New Relic 那样漂亮的实时监控系统我们只需要 InfluxDB/collectd/Grafana 这三个工具,这三个工具的关系是这样的:

采集数据(collectd)-> 存储数据(InfluxDB) -> 显示数据(Grafana)。

  • InfluxDB 是 Go 语言开发的一个开源分布式时序数据库,非常适合存储指标、事件、分析等数据,看版本号(v0.8.8)就知道这个项目还很年轻;

  • collectd 就不用介绍了吧,C 语言写的一个系统性能采集工具;

  • Grafana 是纯 Javascript 开发的前端工具,用于访问 InfluxDB,自定义报表、显示图表等。

下面的安装和配置步骤在 Ubuntu 14.04 Server 64bit 版上完成。升级整个系统后重启:

$ sudo apt-get update$ sudo apt-get upgrade$ sudo reboot

安装 InfluxDB

InfluxDB 是 Go 写的,不依赖任何其他包或库,很干净。安装很容易:

$ wget https://s3.amazonaws.com/influxdb/influxdb_latest_amd64.deb$ sudo dpkg -i influxdb_latest_amd64.deb

启动 InfluxDB:

$ sudo /etc/init.d/influxdb startSetting ulimit -n 65536Starting the process influxdb [ OK ]influxdb process was started [ OK ]

启动后打开 web 管理界面 http://192.168.2.183:8083/ 默认用户名和密码是 root 和 root. InfluxDB 的 Web 管理界面端口是 8083,HTTP API 监听端口是 8086,如果需要更改这些默认设定,修改 InfluxDB 的配置文件 /opt/influxdb/current/config.toml 后重启 InfluxDB 就可以了。

InfluxDB 

InfluxDB

在刚安装好的 InfluxDB 上创建一个名为 collectd 的数据库,可以用命令行创建,也可以用 Web 管理界面操作:

$ curl "http://192.168.2.183:8086/db?u=root&p=root" -d "{\"name\": \"collectd\"}"

InfluxDB

InfluxDB

安装 collectd

安装 collectd:

安装 collectd:


$ sudo apt-get install collectd

配置 collectd 为客户端,收集到数据后直接发给 InfluxDB:


$ sudo vi /etc/collectd/collectd.conf

...

LoadPlugin network

...

<Plugin network>

        Server "192.168.2.183" "25826"

</Plugin>

...

重启 collectd:


$ sudo /etc/init.d/collectd restart

InfluxDB 现在自带一个 collectd 插件来获取 collectd 客户端发来的数据,以前可没这么方便哦,0.8.4 版本以前只能通过 influxdb-collectd-proxy 这样的第三方程序来连接 collectd 和 InfluxDB. 如果你检查一下服务器上打开的端口就会发现 influxdb 插件启动了一个 25826 端口,如果发现 InfluxDB 数据库里没有(收集到)数据,务必检查这个 25826 端口是否正常启动了:


$ sudo netstat -tupln

Active Internet connections (only servers)

Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name

tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      622/sshd

tcp6       0      0 :::8086                 :::*                    LISTEN      668/influxdb

tcp6       0      0 :::22                   :::*                    LISTEN      622/sshd

tcp6       0      0 :::8090                 :::*                    LISTEN      668/influxdb

tcp6       0      0 :::8099                 :::*                    LISTEN      668/influxdb

tcp6       0      0 :::8083                 :::*                    LISTEN      668/influxdb

udp6       0      0 :::25826                :::*                                668/influxdb

InfluxDB 自带的 collectd 插件默认是关闭的,需要手动配置打开 enabled = true,并填上 database = “collectd” 这一行,这里的 “collectd” 就是我们上面创建的那个数据库,更改配置后记得重启 InfluxDB:


$ sudo vi /opt/influxdb/current/config.toml

$ sudo vi /opt/influxdb/shared/config.toml

...

  # Configure the collectd api

  [input_plugins.collectd]

  enabled = true

  # address = "0.0.0.0" # If not set, is actually set to bind-address.

  # port = 25826

  database = "collectd"

  # types.db can be found in a collectd installation or on github:

  # https://github.com/collectd/collectd/blob/master/src/types.db

  # typesdb = "/usr/share/collectd/types.db" # The path to the collectd types.db file

...

$ sudo /etc/init.d/influxdb restart

Setting ulimit -n 65536

Setting ulimit -n 65536

influxdb process was stopped [ OK ]

Setting ulimit -n 65536

Starting the process influxdb [ OK ]

influxdb process was started [ OK ]

现在 InfluxDB 已经准备好接受和处理 collectd 传来的数据了。用命令行或者 Web 管理界面验证一下数据库里是否有数据:


$ curl -G 'http://192.168.2.183:8086/db/collectd/series?u=root&p=root&q=list+series&pretty=true'

[

    {

        "name": "list_series_result",

        "columns": [

            "time",

            "name"

        ],

        "points": [

            [

                0,

                "192.168.2.183/cpu-0/cpu-idle"

            ],

...

        ]

    }

]

InfluxDB


InfluxDB


安装 Grafana

下载 grafana 后解压放到 web 服务器上就可用。这里省去配置 Nginx/Apache 之类的麻烦,直接用最简单的 Web 服务器 python -m SimpleHTTPServer 驱动:


$ wget http://grafanarel.s3.amazonaws.com/grafana-1.9.1.tar.gz

$ tar xzvf grafana-1.9.1.tar.gz

$ cd grafana-1.9.1.tar.gz

$ cp config.sample.js config.js

$ vi config.js

...

      // InfluxDB example setup (the InfluxDB databases specified need to exist)

      datasources: {

        influxdb: {

          type: 'influxdb',

          url: "http://192.168.2.183:8086/db/collectd",

          username: 'root',

          password: 'root',

        },

        ...

      },

...

$ sudo python -m SimpleHTTPServer

用浏览器访问 Grafana,这里的默认端口是 8000:


Grafana

Grafana

Grafana

转载自:http://www.vpsee.com/2015/03/a-modern-monitoring-system-built-with-grafana-collected-influxdb/作者: @vpsee



点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
数据库工程师
手记
粉丝
42
获赞与收藏
203

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消