sunsir 发表于 2019-1-10 11:55:43

利用cacti实现监控

Cacti是一套基于PHP,MySQL,SNMP及RRDTool开发的网络流量监测图形分析工具。Cacti是通过 snmpget来获取数据,使用 RRDtool绘画图形,而且你完全可以不需要了解RRDtool复杂的参数。它提供了非常强大的数据和用户管理功能,可以指定每一个用户能查看树状结 构、host以及任何一张图,还可以与LDAP结合进行用户验证,同时也能自己增加模板,功能非常强大完善,界面友好。Cacti 的发展是基于让 RRDTool 使用者更方便使用该软件,除了基本的 Snmp 流量跟系统资讯监控外,Cacti 也可外挂 Scripts 及加上 Templates 来作出各式各样的监控图。
cacti是用php语言实现的一个软件,它的主要功能是用snmp服务获取数据,然后用rrdtool储存和更新数据,当用户需要查看数据的时候用 rrdtool生成图表呈现给用户。因此,snmp和rrdtool是cacti的关键。Snmp关系着数据的收集,rrdtool关系着数据存储和图表的生成。
Mysql配合PHP程序存储一些变量数据并对变量数据进行调用,如:主机名、主机ip、snmp团体名、端口号、模板信息等变量。
snmp抓到数据不是存储在mysql中,而是存在rrdtool生成的rrd文件中(在 cacti根目录的rra文件夹下)。rrdtool对数据的更新和存储就是对rrd文件的处理,rrd文件是大小固定的档案文件(Round Robin Archive),它能够存储的数据笔数在创建时就已经定义。
与商业监控软件的对比
http://blog.运维网.com/attachment/201311/174141468.jpg
  

Cacti的构架
http://blog.运维网.com/attachment/201311/174232132.jpg
1、数据采集层:靠snmp、命令或者脚本来获取数据,数snmp最常用
2、数据存储层:存储在rrd(环状数据库)数据库中,利用rrdtool来对数据库进行操作。
Pdp:每个多少时间获取一次数据 ,但是数据库中存放的不是pdp,而是经过聚合函数(求取平均值、绝对值.....)后的表格(RRA),这些表格需要数据库(数据源)进行管理,一个数据源可包括多个表格。
3、数据展现层
利用web页来展示


Cacti监控的类型
http://blog.运维网.com/attachment/201311/174342162.jpg
  

Cacti工作原理
http://blog.运维网.com/attachment/201311/174555526.jpg
  

下面我们来通过实例对cacti作进一步的了解
不过在这之前呢,我们先来了解一下snmp和rrdtool

一、配置监控端
1、配置ip参数
http://blog.运维网.com/attachment/201311/174622615.png
2、配置本地yum
http://blog.运维网.com/attachment/201311/174637713.png
3、安装需要的软件
mkdir /mnt/cdrom
mount /dev/cdrom /mnt/cdrom
http://blog.运维网.com/attachment/201311/174658406.png
虽然该主机是NMS(监管设备),但是同时也要监管自己
yum install net-snmp net-snmp-utils -y
4、开启服务
service snmpd start
5、snmp版本
1、2c以及3三个版本,前两个版本靠团体名实现身份验证,属于明文验证;3版本靠账号实现验证,属于密文验证,较为安全,但是也较为麻烦,2c版本较为流行。
6、实用工具实现与agent的信息交流
http://blog.运维网.com/attachment/201311/174746392.png
-v 版本 -c团体名(默认为public) 监控为本机
7、但是我们发现只监控到了SNMPv2-MIB、HOST-RESOURCES-MIB的信息
我们可以再配置文件中设置要监控的内容
/etc/snmp/snmpd.conf
http://blog.运维网.com/attachment/201311/174810980.png
修改后
http://blog.运维网.com/attachment/201311/174831331.png
添加监控tcp的配置
8、查看
service snmpd restart
http://blog.运维网.com/attachment/201311/174904983.png
可以看到TCP的信息都出现了
  

二、配置被监控端
1、安装服务
http://blog.运维网.com/attachment/201311/174941544.png
  

http://blog.运维网.com/attachment/201311/175002536.png
  

2、配置
http://blog.运维网.com/attachment/201311/175053114.png
  

http://blog.运维网.com/attachment/201311/175109262.png
  

http://blog.运维网.com/attachment/201311/175123613.png
  

http://blog.运维网.com/attachment/201311/175133343.png
  

http://blog.运维网.com/attachment/201311/175238651.png
(向监控端出示证明)
  

http://blog.运维网.com/attachment/201311/175318821.png
  

http://blog.运维网.com/attachment/201311/175334232.png
(此服务应用于监管设备上边,应禁用)


http://blog.运维网.com/attachment/201311/175358741.png
  

三、Rrdtool
功能:收集数据、绘图
收集数据
1、上传需要的软件包
http://blog.运维网.com/attachment/201311/175600546.png
2、安装
yum localinstall rrd* --nogpgcheck
3、
rrdtool create test.rrd -s 5 DS:testds:GAUGE:8:0:U RRA:AVERAGE:0.5:1:17280 RRA:AVERAGE:0.5:10:3456
http://blog.运维网.com/attachment/201311/175625975.png
查看每隔五秒的平均值
http://blog.运维网.com/attachment/201311/175642247.png
4、到现在为止数据库和表格都有了,接下来传入数据
从上图看到显示的信息都是按照每隔5秒显示的,但是在实际的环境中我们需要不停地循环的接收数据,这就需要一个脚本来做些控制
vim rrd.sh
http://blog.运维网.com/attachment/201311/175707765.png
执行脚本
bash rrd.sh
等执行一会在查看文件的数据信息
http://blog.运维网.com/attachment/201311/175729375.png
5、rrdtool fetch test.rrd AVERAGE (不指定时间默认为每隔5秒查询一次)
http://blog.运维网.com/attachment/201311/175807492.png
看到已经有信息了
  

四、实现用图形界面来配置Cacti监控工具
1、搭建环境
yum install httpd php php-mysql php-snmp mysql-server perl-DBD-MYSQL php-pdo net-snmp-libs net-snmp-devel ruby ruby-devel
2、开启apache服务和mysql服务并设置为开机启动
http://blog.运维网.com/attachment/201311/175836820.png
service mysqld start
chkconfig mysqld on
为了安全为mysql设置密码
mysqladmin -u root -p password '123'
3、在数据库中新建存放cacti相关资料的数据库,并授权一个账号来管理数据库
http://blog.运维网.com/attachment/201311/175901456.png
4、建立虚拟目录
tar zxvf cacti-0.8.7g.tar.gz
mv cacti-0.8.7g /var/www/html/
5、向数据库中导入数据
cd /var/www/html/ cacti-0.8.7g
mysql -u root -p cacti
页: [1]
查看完整版本: 利用cacti实现监控