cacti原理:

1,构件(步骤):

net_snmp:负责数据采集

rrdtool:数据存储以及绘图

mysql:保存模板和主机对应的信息

数据采集:cacti使用poller(轮询器)收集数据,主要使用snmp协议从远端的设备上收集数据。

数据存储:cacti使用rrdtool(环形数据库)存储收集到的数据(时间序列数据)。rrd会将原始数据与整合到的数据进行合并,以使得历史数据的存储节省空间。

数据展示:rrdtool绘图功能。

2,工作原理:

net_snmp协议定时采集数据,保存到rrd,当用户需要查看某个主机对应的监控信息的时候可以在MySQL中寻找对应的主机ip等信息,然后在命令rrd绘制出图形

3,监控对象:

网络流量,cpu使用率,硬盘使用率等

 

zabbix原理:

1,构造:

agent:被监控对象

server:负责数据收集

proxy:代理

2,原理:

主被动模式:

主被动模式是相对于客户端来说的,主动就是客户端主动将采集的数据发送给server端,而被动模式是server过来告诉agent自己需要什么东西,agent采集。

zabbix和nagios的报警机制一样,通过插件模板来实现

3,监控对象:

网络状态

自带监控项比较多

 

nagios原理:

1,构件:

主程序(Nagios Daemon):Nagios的主部件,实现了监控,性能,通知,事件处理功能。这些功能都是抽象的逻辑和调度,并没有实际的与设备交互的监控实现,与设备的交互都是在下面一层的Plugin种实现的,这些就是Nagios认为可变部分。

Web Interface:的Web页面,Nagios的Web容器是Apache HTTPD,Nagios开发了一个HTTPD模块,并提供Web页面。Web Interface与Nagios Daemon之间通过文件接口交互,Web逻辑读取Nagios的状态文件(status.dat),展示其监控信息。

插件程序(nagios-plugins)

四个可选的附件(NRPE,NSCA,NSClient++,NDOUtils)

NDOUtils:用来将Nagios的配置信息和各event产生的数据存入数据库,以实现这些数据的减速和快速处理  (服务端)

NRPE   NSClient:工作在客户端

NSCA:被动(让被监控的主机主动将监控信息发送给服务器)

需要同时安装在服务端和客户端NSCA ---send-nsca

2,原理:

基于状态的改变来实现报警,当状态改变之后会先不警告(软状态),当两次采集之后状态都改变了再通知(硬状态)

3,监控对象:注重主机和服务的监控

自带监控项比较少

本文转自   Taxing祥   51CTO博客,原文链接:http://blog.51cto.com/12118369/1968090