安装collectd (server,agent),influxdb,grafana

参考:http://www.tnkyou.com/wk/doku.php?id=collectd
collectd server用于收集collectd agent发送过来的数据,是一个被动的过程!
安装collectd需要支持的插件<code>yum install -y net-snmp-devel(snmp插件依赖这个库)yum install -y rrdtool-devel(rrdtool插件依赖这个库)yum install -y libgcrypt-devel(network插件加密依赖这个库)yum install -y python-devel(依赖这个库)yum install -y perl-devel(编译依赖perl库)yum install -y python-requests(python influxdb plugin 的依赖库)yum install -y liboping-devel (ping 依赖的库)</code>

安装collectd<code>wget http://collectd.org/files/collectd-5.4.2.tar.gztar zxvf collectd-5.4.2.tar.gzcd collectd-5.4.2./configure –prefix=/usr/local/collectd –enable-all-pluginsmake ; make install</code>

修改collectd配置文件<code>cd /usr/local/collectd/etc/cp collectd.conf collectd.conf.bak(collectd.conf文件中具体内容见文章末尾collectd.conf.server)</code>

collectd配置成服务<code>vim /etc/rc.d/init.d/collectd (collectd 文件中具体内容见文章末尾collectd.txt)chmod u+x /etc/rc.d/init.d/collectdchkconfig –add collectdchkconfig collectd onserver collectd {start|stop|restart|status|help}</code>

执行./configure之后会输出一张支持插件的列表(如下图)如果需要安装别的插件需要重新编译collectd

安装collectd (agent)
collectd agent定时收集数据并发送到collectd server,是一个主动的过程!
yum install -y net-snmp

chkconfig snmpd on # snmp设置成开机启动

echo “view systemview included .1”

/etc/snmp/snmpd.conf # 让snmp监控所有字段
service snmpd start

yum install -y net-snmp-utils # snmp客户端工具,用于调试。
常见调试命令

snmpwalk -v 2c -c public 192.168.16.144 # 查看所有字段

snmpwalk -v 2c -c public 192.168.16.144 system # 查看系统字段

其他步骤和安装collectd server一样,但是不需要额外安装插件

安装influxdb

用于接收collectd 发送过来的数据,并写入数据库。并在此基础上提供了查询功能!
wget https://s3.amazonaws.com/influxdb/influxdb-latest-1.x86_64.rpm

rpm -ivh influxdb-latest-1.x8664.rpm - chkconfig influxdb on - service influxdb start - 登录influxdb管理后台 http://192.168.16.146:8083/ - 默认账号:root 密码:root - 创建一个数据库 - curl https://raw.githubusercontent.com/collectd/collectd/master/src/types.db -o /opt/influxdb/shared/types.db # 下载collectd插件支持的数据类型映射表 - vim /opt/influxdb/shared/config.toml(配置influxdb的collectd插件,选择数据库引擎,并重启influxdb)<code> [inputplugins.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 = “/opt/influxdb/shared/types.db”default-engine = “rocksdb” # 选择数据库引擎</code>
influx常用命令

list series

select * from /.*/

select * from “10.0.2.220/interface-eth0/if_octets” where dsname = 'tx'表明用双引号,列值用单引号

安装Grafana
一个纯web显示程序,可以从influxdb数据源读取数据
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

最后将整个目录放到nginx或apache下即可

登录grafana http://192.168.16.146config.js <code># 取消如下代码的注释datasources: { influxdb: { type: 'influxdb', url: “http://192.168.16.146:8086/db/collectd”, username: 'root', password: 'root', }, },</code>
配置文件

collectd.conf(server端)

----------- global setting ---------------FQDNLookup false # 关闭主机名验证Interval 10 # 全局采样时间间隔Timeout 2 ReadThreads 5 # 开启 5 个读进程WriteThreads 5 # 开启 5 个写进程#------------ simple plugin ----------------LoadPlugin cpuLoadPlugin interfaceLoadPlugin loadLoadPlugin memoryLoadPlugin disk#------------ complex plugin ---------------LoadPlugin snmpLoadPlugin statsd # 默认开启8125端口LoadPlugin rrdtoolLoadPlugin networkLoadPlugin logfile#------------ detail for complux plugin ----------------<Plugin logfile> LogLevel info # 日志级别 debug|info|notice|warning|err File "/usr/local/collectd/collectd.log" # 日志文件位置</Plugin><Plugin network> Server "192.168.16.146" "25826" # 自己作为客户端,将数据发送到某个服务器的ip,port <Listen "192.168.16.145" "25826"> # 自己作为服务器,绑定一个接收客户端数据的ip,port SecurityLevel Sign # 验证级别 debug|info|notice|warning|err AuthFile "/usr/local/collectd/etc/authfile.txt" # 验证文件,账号密码以键值对的方式存储,如:upyun: 123 </Listen> Forward true</Plugin><Plugin rrdtool> # 将客户端和本机的数据写入rrd文件 DataDir "/usr/local/collectd/var/lib/collectd/rrd"</Plugin><Plugin snmp> # 用snmp插件去主动收集客户端数据 <Data "hr_users"> Type "users" # 见/usr/local/collectd/share/collectd/types.db Table false Instance "" Shift -1 Values "HOST-RESOURCES-MIB::hrSystemNumUsers.0" # 收集客户端用户登录数 </Data> <Host "192.168.16.144"> Address "192.168.16.144" # 客户端ip Version 2 # snmp 协议版本 Community "public" # 见/etc/snmp/snmpd.conf中的 community字段 Collect "hr_users" # 收集哪些数据,可以指定多个<Data></Data> Interval 10 # 采样周期,可以覆盖全局变量 Interval </Host></Plugin>

collectd.conf(agentd端)

----------- global setting ---------------FQDNLookup falseInterval 10Timeout 2ReadThreads 5WriteThreads 5#------------ simple plugin ----------------LoadPlugin cpu LoadPlugin interface LoadPlugin loadLoadPlugin memoryLoadPlugin disk##------------ complex plugin ---------------LoadPlugin statsdLoadPlugin networkLoadPlugin logfile##------------ detail for complux plugin ----------------<Plugin logfile> LogLevel info File "/usr/local/collectd/collectd.log"</Plugin><Plugin network> <Server "192.168.16.145" "25826"> SecurityLevel Sign # 校验级别,和服务器端保持一致 Username "upyun" # 账号 Password "123" # 密码 </Server></Plugin>

collectd(collectd服务配置脚本)

!/bin/bash# chkconfig: 2345 10 90# description: collectd start() { /usr/local/collectd/sbin/collectd}stop() { kill -9 pidof collectd}restart() { stop start}status(){ echo $"Usage: {start|stop|restart|status|help}"}case "$1" in start) pidof collectd > /dev/null if [ $? == 1 ] ; then start echo "collectd started" else echo "collectd is already runing..." fi ;; stop) stop echo "collectd stop" ;; restart) restart ;; status) pidof collectd > /dev/null if [ $? == 0 ] ; then echo "collectd is runing..." else echo "collectd is not runing..." fi ;; *) status exit 2esacexit $?

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,219评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,363评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,933评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,020评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,400评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,640评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,896评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,597评论 0 199
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,327评论 1 244
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,581评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,072评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,399评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,054评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,083评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,849评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,672评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,585评论 2 270

推荐阅读更多精彩内容