Cacti是一套基于PHP,MySQL,SNMP及RRDTool开发的网络流量监测图形分析工具。Cacti是通过 snmp get来获取数据,使用 RRDtool绘画图形,而且你完全可以不需要了解RRDtool复杂的参数。它提供了非常强大的数据和用户管理功能,可以指定每一个用户能查看树状结构、host以及任何一张图,还可以与LDAP结合进行用户验证,同时也能自己增加模板,功能非常强大完善。界面友好。软件 Cacti 的发展是基于让 RRDTool 使用者更方便使用该软件,除了基本的 Snmp 流量跟系统资讯监控外,Cacti 也可外挂 Scripts 及加上 Templates 来作出各式各样的监控图。
Cacti是用php语言实现的一个软件,它的主要功能是用snmp服务获取数据,然后用rrdtool储存和更新数据,当用户需要查看数据的时候用rrdtool生成图表呈现给用户。因此,snmp和rrdtool是cacti的关键。Snmp关系着数据的收集,rrdtool关系着数据存储和图表的生成。即如果想监控一台主机,需要在被监控主机上安装net-snmp相关软件包,在监控主机上安装rrdtool和cacti。
Mysql配合PHP程序存储一些变量数据并对变量数据进行调用,如:主机名、主机ip、snmp团体名、端口号、模板信息等变量。
通过snmp抓到的数据不是存储在mysql中,而是存在rrdtool生成的rrd文件中(在cacti根目录的rra文件夹下)。rrdtool对数据的更新和存储就是对rrd文件的处理,rrd文件是大小固定的档案文件(Round Robin Archive),它能够存储的数据笔数在创建时就已经定义。
利用cron定期执行php脚本代码,通过snmp读取指定监控项目的snmp信息,然后将结果保存到rrdtool数据文件中。在web监控界面中通过php读取rrdtool并生成指定监控项目和指定时间段的监控曲线图。
Data Retrieval
Cacti首先要做的工作就是收集数据,cacti使用Poller(轮询器)收集数据。Poller是操作系统scheduler的扩展,如在类Unix系统中的crontab。现在的IT设施中会有许多不同的设备,如服务器、网络设备等,cacti主要使用SNMP协议来从远端的设备上收集数据,所有可以使用SNMP协议的设备都可以被cacti监控。
Data Storage
存储收集到的数据有许多方法,可以使用数据库、平面文件等,cacti使用的是RDDTool。RRD是Round Robin Database(环形数据库)的缩写,RRD用来存储和显示时间序列数据,如网络带宽、机房温度、服务器负载等,RRD使用非常紧凑的方式存储数据,数据不会随着时间的推移而增大,RRD还可以生成美观的图形。这些特性使得cacti没有存储需求。RRD也做一席位其他的工作,如RRD会将原始数据与已整合的数据进行合并,以使得历史数据的存储节省空间,RRD支持的整合功能包括:AVERAGE, MAXIMUM, MINIMUM和LAST。
Data Presentation
Cacti最大的一个特点是内置了RRDTool画图功能,将其与通用的web服务器相结合,可以实现在任意平台上使用浏览器就可以查看监控画面。
安装RRDTool和SNMP
#安装RRDTool
yum install rrdtool rrdtool-devel rrdtool-php rrdtool-perl #安装 snmp,因为此事例中监控和被监控主机是同一台,所以在此主机中安装net-snmp相关软件包
yum -y install net-snmp* #安装其他依赖,Spine依赖
yum -y install mysql-devel openssl-devel #启动snmp
service snmpd start #开机启动snmp
chkconfig snmpd on
下载Cacti和Spine
Cacti: wget http://www.cacti.net/downloads/cacti-0.8.8h.tar.gz
Spine: wget http://www.cacti.net/downloads/spine/cacti-spine-0.8.8h.tar.gz
由于默认cmd.php来轮询数据,速度会很慢,特别是在监控节点比较多的情况下,cmd.php就更显不足了,因此我们采用Spine来轮询数据。cacti-spine是一个由C语言开发的,用于替代cmd.php的快速获取速度的引擎。
#解压cacti,需要使用sql
tar -xzf cacti-0.8.8h.tar.gz
MySQL中创建给Cacti使用的数据库,帐号等信息,并导入Cacti数据表信息
#登录
mysql -u root -p #创建数据库
create database if not exists 数据库名 default charset utf8 COLLATE utf8_general_ci; #创建用户,并设置对数据库的访问权限
grant all on 数据库名.* to '用户名'@'%' identified by '密码'; #刷新系统授权表,使设置生效
flush privileges; #导入cacti数据库文件
use 数据库名
source 解压后的cacti目录/cacti.sql
安装Cacti
#把已经解压的 cacti-0.8.8h 挪到 nginx 指定的网站目录,可以作为一个网站,也可以作为一个网站目录
mv cacti-0.8.8h /网站目录/cacti #修改cacti的MySQL配置信息
vim /网站目录/cacti/include/config.php #如果用的cacti作为一个网站,非某网站的子目录,需要修改include/global.php,否则一直跳转url,且跳转地址错误
vim /网站目录/cacti/include/global.php #把 $url_path = '/cacti/' 改为 $url_path = '/';
#修改 Nginx 配置,添加 cacti 网站 vim /Nginx配置文件路径/nginx.conf #重启 Nginx service nginx restart
访问Cacti
#会提示安装,安装完登录,初始帐号密码都是 admin
http://xxx.xxx.xxx/
安装Spine
#编译安装Spine
tar -xzf cacti-spine-0.8.8h.tar.gz cd cacti-spine-0.8.8h ./configure
make && make install #拷贝配置文件
cp /usr/local/spine/etc/spine.conf.dist /etc/spine.conf #修改配置文件中的给Spine使用的数据库信息
vim /etc/spine.conf
测试Spine
#执行此命令会输出如下:
#SPINE: Using spine config file [/etc/spine.conf]
#SPINE: Version 0.8.8h starting
#SPINE: Time: 0.1129 s, Threads: 5, Hosts: 2 /usr/local/spine/bin/spine
配置Cacti与Spine
#cacti的web配置界面选择setting settings->paths->Spine Poller File Path [/usr/local/spine/bin/spine]
settings->poller->Poller Type [spine]
console->settings->poller->Maximum Threads per Process []
定时采集,每分钟采集一次
#把如下内容加入crontab
* * * * * /PHP执行文件所在目录/php /cacti网站所在目录/poller.php
配置被监控主机的snmp
参考:http://www.cnblogs.com/JohnABC/p/6073445.html
添加被监控主机
添加完主机,如果成功,则可以通过snmpget获取到可以监控的项(与主机模版相关的“数据查询”、“图形模版”)。必须至少选择一个数据查询或图形模板与新设备关联,否则无法在下一步创建图表。如果没有可用的图形模板或数据查询适用设备,可以官网查询模板库或自己创建。
cacti 是时间序列展示工具
nagios 状态监控工具
snmp 有三个版本。被监控端启动snmp服务,监听snmpget请求,根据请求响应指定结果,有CPU,内存等信息。中间认证机制是靠community(共同体)实现的。监控端:“老子是aaa团伙的,你要是认可aaa团伙就给放行”,被监控端:“aaa团伙我放心”。community相当于密码。
snmp与MIB库。
a