cacti+nagios 之cacti整合nagios(四)

1、原理php

整合cacti和nagios是利用了cacti的一个插件nagios for cacti;它的原理是将nagios的数据经过ndo2db导入到mysql数据库(cacti)的库中;而后cacti读取数据库信息将nagios展示出来;html

1、安装cacti扩展模块mysql

Cacti扩展模块须要下载安装cacti-plugin,cacti-0.8.8a及之后版本已经集成不须要安装(可是我使用的0.8.8b还须要安装很郁闷,若是使用的是老版本cacti,扩展模块安装以下:ios

Cd   /root/cactinagiossql

Wget  http://www.cacti.net/downloads/pia/cacti-plugins-0.8.7h-PA-v3.0.tar.gz数据库

Mv   cacti-plugin-0.8.7h-PA-v3.0.tar.gz  cacti-plugin-arch.tar.gzjson

Tar  -xf  cacti-plugin-arch.tar.gz dom

Cp  cacti-plugin-arch/*   /var/www/html/cacti/socket

Cd  /var/www/html/cacti/tcp

Mysql  -u cacti –p ‘cacti’ cacti

Patch  -p1 –N 而后登录cacti;点击consoleàuser Management àadmin àPlugin Mangement打开将其勾选上;而后点击保存便可;
 

安装Ndoutils
cd /root/cactinagios
wget http://jaist.dl.sourceforge.net/project/nagios/ndoutils-2.x/ndoutils-2.0.0/ndoutils-2.0.0.tar.gz
tar zxvf ndoutils-2.0.0.tar.gz
cd ndoutils-2.0.0
./configure  –prefix=/var/www/html/nagios/  –with-mysql-inc=/usr/include/mysql   –with-mysql-lib=/usr/lib64/mysql  –enable-mysql  –disable-pgsql   –with-ndo2db-user=nagios –with-ndo2db-group=nagios
 make
  二、准备配置文件
cd db
./installdb -u cactier -p 123456 -h localhost -d cactidb 
cd ..
[root@nagios ndoutils-2.0.0]# cp src/{ndomod-4x.o,ndo2db-4x,log2ndo,file2sock} /usr/local/nagios/bin 
#nagios是4.x版本的就使用ndomod-4x.o和ndo2db-4x,若是是3.x版本就复制对应的3x文件
[root@nagios ndoutils-2.0.0]# cp config/ndomod.cfg-sample /var/www/html/nagios/etc/ndomod.cfg
[root@nagios ndoutils-2.0.0]# cp config/ndo2db.cfg-sample /var/www/html/nagios/etc/ndo2db.cfg
[root@nagios ndoutils-2.0.0]# cd /var/www/html/nagios/etc/
[root@nagios etc]# chown nagios:nagios ndo2db.cfg ndomod.cfg
[root@nagios etc]# chmod 664 ndo2db.cfg ndomod.cfg
[root@nagios etc]# cd /var/www/html/nagios/bin
[root@nagios bin]# mv ndo2db-4x ndo2db
[root@nagios bin]# mv ndomod-4x.o ndomod.o
[root@nagios bin]# chown nagios:nagios *
  三、修改配置文件
[root@nagios bin]# vi /usr/local/nagios/etc/nagios.cfg
#注意,broker_module和config_file放在一行    broker_module=/var/www/html/nagios/bin/ndomod.o config_file=/var/www/html/nagios/etc/ndomod.cfgevent_broker_options=-1 
process_performance_data=1
[root@nagios bin]# vi /var/www/html/nagios/etc/ndo2db.cfg
    socket_type=tcp
    db_servertype=mysql
    db_host=localhost
    db_port=3306
    db_name=cactidb
    db_prefix=npc_
    db_user=cactier
    db_pass=123456
[root@nagios bin]# vi /var/www/html/nagios/etc/ndomod.cfg
    output_type=tcpsocket
   output=127.0.0.1
四、启动守护进程
[root@nagios bin]# /var/www/html/nagios/bin/ndo2db -c /var/www/html/etc/ndo2db.cfg
[root@nagios bin]# cd /root/cactinagios/ndoutils-2.0.0
[root@nagios ndoutils-2.0.0]# cp ./daemon-init /etc/init.d/ndo2db
[root@nagios ndoutils-2.0.0]# chmod +x /etc/init.d/ndo2db
[root@nagios ndoutils-2.0.0]# service ndo2db status
[root@nagios ndoutils-2.0.0]# chkconfig –add ndo2db 
[root@nagios ndoutils-2.0.0]# chkconfig ndo2db on

4、安装NPC插件

    介绍:全称Nagios Plugin for Cacti,将nagios的数据经过ndo2db导入到mysql数据库(前面设置的npc_开头的表),而后cacti读取数据库信息将nagios的结果经过NPC展现出来。
  一、安装npc
[root@nagios ndoutils-2.0.0]# cd /root/cactinagios
[root@nagios nagios]# wget http://down.drv5.cn/www.drv5.cn/npc-2.0.4.tar.gz
[root@nagios nagios]# tar zxvf npc-2.0.4.tar.gz
[root@nagios nagios]# mv npc /var/www/html/cacti/plugins/
[root@nagios nagios]# vi /var/www/html/cacti/include/config.php
$plugins[] = ‘npc’;
二、页面设置npc
(1)user management–>admin–>勾上Plugin Management
(2)Plugin Management–>点击install图标、点击enable图标
(3)settings–>NPC–>以下所示:
 Remote Commands:
 /var/www/html/nagios/var/rw/nagios.cmd
 http://192.168.10.16/nagios

三、安装json:支持npc
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。
 注意:先执行第4步的php -m查看是否加载了json,有则跳过三、4步我这里有;

查看是否有json被加载:
[root@nagios json-1.2.1]# php -m
修改数据库:

[root@nagios json-1.2.1]# mysql -ucacti -pcacti mysql>use cacti; mysql>ALTER TABLE npc_eventhandlers ADD long_output TEXT NOT NULL DEFAULT ” AFTER output; mysql>ALTER TABLE npc_hostchecks ADD long_output TEXT NOT NULL DEFAULT ” AFTER output; mysql>ALTER TABLE npc_hoststatus ADD long_output TEXT NOT NULL DEFAULT ” AFTER output; mysql>ALTER TABLE npc_notifications ADD long_output TEXT NOT NULL DEFAULT ” AFTER output; mysql>ALTER TABLE npc_servicechecks ADD long_output TEXT NOT NULL DEFAULT ” AFTER output; mysql>ALTER TABLE npc_servicestatus ADD long_output TEXT NOT NULL DEFAULT ” AFTER output; mysql>ALTER TABLE npc_statehistory ADD long_output TEXT NOT NULL DEFAULT ” AFTER output; mysql>ALTER TABLE npc_systemcommands ADD long_output TEXT NOT NULL DEFAULT ” AFTER output; mysql>ALTER TABLE npc_services ADD importance smallint(6) NOT NULL DEFAULT ’0′; mysql>ALTER TABLE npc_hosts ADD importance smallint(6) NOT NULL DEFAULT ’0′;  mysql>ALTER TABLE npc_contacts ADD minimum_importance smallint(6) NOT NULL DEFAULT ’0′;  mysql>quit   六、重启服务 [root@nagios ~]# service mysqld restart [root@nagios ~]# service httpd restart [root@nagios ~]# service ndo2db restart [root@nagios ~]# service nagios restart 七、观察日志 [root@nagios ~]# tail /var/log/html/nagios/var/nagios.log [root@nagios ~]# tail /var/www/html/cacti/log/cacti.log [root@nagios ~]# tail /var/log/mysqld.log [root@nagios ~]# tail /var/log/messages

相关文章
相关标签/搜索