Cacti是一款优秀的开源监控软件,使用php实现,主要特点是使用snmp服务获取数据,然后用rrdtool存储和更新数据,当用户查看数据的时候,rrdtool生成图表呈现给用户。在CentOS7后,默认数据库为MariaDB,其为MySQL的一个分支,用其存储变量并进行调用。MariaDB数据库并不存储snmp捕获到的数据,snmp捕获到的数据,存在于rrdtool生成的rrd文件中,这些文件位于cacti目录下的rra目录中。
一、相关软件的安装
多数使用yum即可安装:
二、配置SNMP
①将41行(各有不同,请自行查找)下的default更改为127.0.0.1
②将62行(各有不同,请自行查找)下的systemview更改为all
③将85行(各有不同,请自行查找)下的#注释掉
④启动snmp
三、MariaDB数据库配置
①启用MariaDB数据库
②为root用户设置密码(以wang为例),并修改登录权限,默认密码为空
③添加cacti用户和cacti数据库,并为其设置权限
四、Cacti配置
①下载cacti
②将cacti的表内容导入创建的数据库
③分别编辑两个.php文件
修改内容相同,内容如下:
④修改文件属性:
⑤建立调度任务:
⑥启用http服务
⑦浏览器输入 http://localhost/cacti或者127.0.0.1/cacti 访问cacti管理页面
如出现:
Forbidden
You don't have permission to access /cacti on this server.
这是因为开启了SeLinux导致权限问题
1).查看SELinux状态:
2).关闭SELinux:
a、临时关闭(不用重启机器):
b、修改配置文件需要重启机器:
将SELINUX=enforcing 改为SELINUX=disabled
重启机器即可
注:如关闭后还是提示问题,可能是防火墙问题:
五、安装Spine
由于默认cmd.php来轮询数据,速度会很慢,特别是在监控节点比较多的情况下,cmd.php就更显不足了,因此我们采用Spine来轮询数据。cacti-spine是一个由C语言开发的,用于替代cmd.php的快速获取速度的引擎。
①下载并编译安装
②修改访问数据库的用户名密码信息
注:spine默认配置文件需要放在/etc才会生效,否则测试时会报如下错误:
SPINE: Poller[0] FATAL: Unable to read configuration file! (Spine init)
③测试是否正常
④进入Cacti页面设置spine路径
Console -> Configuration -> Settings -> Paths -> Alternate Poller Path -> Spine Poller File Path
/usr/local/spine/bin/spine
⑤修改Cacti使用的Poller Type
Console -> Cacti Settings->Poller->Poller Type
在下拉中选择spine
不能出图的几个问题:
①安装Cacti后,完全无图,这是因为rrdtool没有完全安装
②如不能出图,可能是时钟问题,如下:
1).
2).cron的时间与poller.php的时间设置错误
一般poller.php的更新时间为60s,所以cron里边也要设置成每分钟更新一次
3).
OK,数据采集已经正常啦。
4.)进入Cacti查看,已经OK了
本文转自 结束的伤感 51CTO博客,原文链接:http://blog.51cto.com/wangzhijian/1680278