Cacti软件准备 php-devel-5.1.6-27.el5.i386.rpm php-json-ext-1.2.1.tar.bz2 php-mysql-5.1.6-40.el5_9.i386.rpm(如果不安装,则php连不上mysql) php-pdo-5.1.6-40.el5_9.i386.rpm(可能是php-mysql的依赖包,在yum安装php-mysql时连带安装) yum -y install php-devel php-mysql php-pdo php-json-ext不能yum安装上,因此需要手工安装。参见下面的安装过程。 Cacti服务器软件安装参考资料http://viong.blog./844766/286701 http://viong.blog./844766/288278 http://www.cacti.net http://www.aydnw.com/html/database/mysql/22526.html http://peaceweb.blog./3226037/1065783 Json安装#rpm -ivh php-devel-5.1.6-27.el5.i386.rpm tar jxvf php-json-ext-1.2.1.tar.bz2 cd php-json-ext-1.2.1 phpize //如果执行不了,则可能没有安装php-devel Configuring for: PHP Api Version: 20041225 Zend Module Api No: 20050922 Zend Extension Api No: 220051025 ./configure make && make install find / -name *json.so /usr/lib/php/modules/json.so /root/soft/php-json-ext-1.2.1/modules/json.so /root/soft/php-json-ext-1.2.1/.libs/json.so vi /etc/php.d/json.ini //添加以下内容 extension=json.so 保存退出 service httpd restart 测试PHP是否支持json扩展: vi /var/www/html/test.php 添加以下内容 phpinfo();
phpinfo(INFO_GENERAL);
phpinfo(1);
?> 保存退出 测试PHP连接mysql: 首先需要根据以下内容安装好mysql并启动,然后创建测试脚本: vi /var/www/html/testdb.php 添加以下内容 保存退出 如果没有安装php-mysql,则不会显示成功或者失败。密码不正确,权限不对当然也不能连接哦。 Rrdtool安装http://pkgs.repoforge.org/rrdtool/ #yum install libdbi 或 # rpm -ivh libdbi-0.8.1-2.1.i386.rpm # rpm -ivh lua-5.1.4-2.el5.rf.x86_64.rpm rpm -ivh lua-5.1.4-2.el5.rf.i386.rpm 以上两个为rrdtoo的依赖包。 rpm -ivh rrdtool-1.4.7-1.el5.rf.x86_64.rpm rrdtool-devel-1.4.7-1.el5.rf.x86_64.rpm perl-rrdtool-1.4.7-1.el5.rf.x86_64.rpm 以上三个包要一起安装否则会报一些错误,如找不到perl(RRDp) 什么的。 # rpm -ivh perl-rrdtool-1.4.7-1.el5.rf.i386.rpm rrdtool-devel-1.4.7-1.el5.rf.i386.rpm rrdtool-1.4.7-1.el5.rf.i386.rpm Mysql安装yum install mysql-server yum install mysql-devel yum install mysql Cacti安装1, 安装Cacti包 # tar -zxvf cacti-0.8.8a.tar.gz mv cacti-0.8.8a /var/www/html/cacti/ chown -R root.root /var/www/html/cacti/ 2, 配置mysql mysql -u root -h 127.0.0.1 -p Enter password: mysql> create database nagios; Query OK, 1 row affected (0.01 sec) mysql> grant all on nagios.* to ndouser@localhost identified by '111111'; GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '111111' WITH GRANT OPTION; flush privileges; quit; 到cacti根目录下把cacti.sql中的数据导入到数据库cacti中 #cd /var/www/html/cacti mysql -uroot -p nagios<cacti.sql[ align]3," 配置mysql连接参数[="" var="" www="" html="" cacti[="" include="" config.php="" 如果不想修改以下参数,则可以依此创建数据库和用户[="" =="" "mysql";="" 以上数据库及用户就是这么创建的[="" "nagios";[="" "localhost";[="" "ndouser";[="" "ndopassword";[="" "3306";[="" false;[="" "="" cacti="" ";="" 将其他的="" $url_path="/" ;="" 将其注销掉[="" array();="" 这个参数如果是注销掉的话,则取消注销让其生效;[="" global.php="" 这里也一样[="" "mysql";[="" 同时,也打开$url_path="/cacti/" ;[="" tar="" -zxvf="" cacti-plugin-0.8.7g-pa-v2.8.tar.gz[="" cacti-plugin-arch="" [="" cacti-plugin-0.8.7g-pa-v2.8.diff="" pa.sql="" -p1="" -n="" <cacti-plugin-0.8.7g-pa-v2.8.diff[="" -uroot="" -p="" nagios="" /dev/null 2>&1 [iyunv@cacti-qmail cacti]# crontab -e */5 * * * * php /var/www/html/cacti/poller.php > /dev/null 2>&1 也可手工跑一次: /usr/bin/php /var/www/html/cacti/poller.php 手工跑的时候报错: 1)# php /var/www/html/cacti/poller.php PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php/modules/mysql.so' - /usr/lib/php/modules/mysql.so: cannot open shared object file: No such file or directory in Unknown on line 0 PHP Notice: Constant URL_PATH already defined in /var/www/html/cacti/include/global.php on line 121 网上搜了下说是MySQL-shared-community没安装,到以下网址下载对应的版本(先查mysql的版本:rpm -qa|grep mysql。我查到的版本是mysql-5.0.95-5.el5_9,因此下载MySQL-shared-community-5.0.95-1.rhel5.i386.rpm): http://rpm.pbone.net/index.php3?stat=3&limit=2&srodzaj=3&dl=40&search=MySQL-shared-community 2)PHP Warning: strtotime(): It is not safe to rely on the system's timezone settings. vi /etc/php.ini date.timezone=PRC 安装后还有问题: # php /var/www/html/cacti/poller.php PHP Notice: Constant URL_PATH already defined in /var/www/html/cacti/include/global.php on line 121 FATAL: Cannot connect to MySQL server on 'localhost'. Please make sure you have specified a valid MySQL database name in 'include/config.php' 将include/config.php中的localhost,改成127.0.0.1也不行,然后执行: 然后执行了下:grant all on nagios.* to ndouser@localhost identified by 'ndopassword'; 还是有错: # php /var/www/html/cacti/poller.php PHP Notice: Constant URL_PATH already defined in /var/www/html/cacti/include/global.php on line 121 PHP Notice: Constant OPER_MODE_NATIVE already defined in /var/www/html/cacti/include/global_constants.php on line 192 PHP Notice: Constant OPER_MODE_RESKIN already defined in /var/www/html/cacti/include/global_constants.php on line 193 PHP Notice: Constant OPER_MODE_IFRAME_NONAV already defined in /var/www/html/cacti/include/global_constants.php on line 194 sh: -q: command not found sh: -: command not found 半天有憋出来两行: 07/10/2013 01:25:59 PM - POLLER: Poller[0] Maximum runtime of 298 seconds exceeded. Exiting. 07/10/2013 01:25:59 PM - SYSTEM STATS: Time:298.7934 Method:cmd.php Processes:1 Threads:N/A Hosts:2 HostsPerProcess:2 DataSources:0 RRDsProcessed:0 不过再次运行报一些警告信息,先不管他。 有时候执行 php -v ,报以下错误: PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib64/php/modules/json.so' - /usr/lib64/php/modules/json.so: undefined symbol: ZVAL_DELREF in Unknown on line 0 解决的办法也是需要安装MySQL-shared-community。 # yumdownloader php-common # rpm -Uvh --force php-common*.rpm # service httpd reload # rm php-common*.rpm 此后,执行php -v就正确了: # php -v PHP 5.3.3 (cli) (built: Jul 12 2013 20:35:47) Copyright (c) 1997-2010 The PHP Group Zend Engine v2.3.0, Copyright (c) 1998-2010 Zend Technologies [iyunv@nagios-test ~]# 配置cacti http://127.0.0.1/cacti/install/ 里面的所有的项全部变绿色就行了,否则安装相关的包,如net-snmp有关的包。 输入用户名和密码admin/admin,第一次需要强行修改密码。 Npc安装 NPC(Nagios Plugin for Cacti)是一个Cacti插件,安装后可以在Cacti界面里使用Nagios的功能。 # tar -zxvf npc-2.0.4.tar.gz mv npc/ /var/www/html/cacti/plugins/ vi /var/www/html/cacti/include/global.php 添加以下参数 $plugins= array(); $plugins[] = 'npc'; 如下图: 保存退出 修改ndo2db.cfg vi /usr/local/nagios/etc/ndoutils/ndo2db.cfg db_prefix=nagios_ 修改为db_prefix=npc_ 查看日志
tail -100 /var/log/messages
tail -100 /usr/local/nagios/var/nagios.log
tail -100 /usr/local/nagios/var/ndo2db.debug
3、cacti插件npc提示no hosts
tail -100 /var/log/messages
localhost ndo2db-3x: mysql_error: 'Unknown column 'long_output' in 'field list''
添加缺失的对应字段(这里可能会报不能使用默认值,可将DEFAULT ''去除后重新执行)
ALTER TABLE npc_eventhandlers ADD long_output TEXT NOT NULL DEFAULT '' AFTER output;
ALTER TABLE npc_hostchecks ADD long_output TEXT NOT NULL DEFAULT '' AFTER output;
ALTER TABLE npc_hoststatus ADD long_output TEXT NOT NULL DEFAULT '' AFTER output;
ALTER TABLE npc_notifications ADD long_output TEXT NOT NULL DEFAULT '' AFTER output;
ALTER TABLE npc_servicechecks ADD long_output TEXT NOT NULL DEFAULT '' AFTER output;
ALTER TABLE npc_servicestatus ADD long_output TEXT NOT NULL DEFAULT '' AFTER output;
ALTER TABLE npc_statehistory ADD long_output TEXT NOT NULL DEFAULT '' AFTER output;
ALTER TABLE npc_systemcommands ADD long_output TEXT NOT NULL DEFAULT '' AFTER output;
FLUSH PRIVILEGES; 重启ndo2db nagios 服务 Shell>service ndo2db restart Shell>/usr/local/nagios/bin/nagios -d /usr/local/nagios/etc/nagios.cfg NPC界面设置 点击(console)菜单栏 user management------->admin 在realm permission---plugin management(打勾) 返回(console)菜单栏,点击configuration--------plugin management—安装并激活npc插件 返回(console)菜单栏,点击configuration-------settings----NPC,修改一下三个参数。这里的url的ip需要根据自己安装的nagios的ip地址进行填写。 /usr/local/nagios/var/rw/nagios.cmd http://192.168.0.51/nagios 返回(console)菜单栏,点击插件链接区-NPC
但是看npc里发现空白的,没有数据,是因为php没有PDO_MYSQL支持,所以安装PDO_MYSQL 2. # tar zxvf PDO_MYSQL-1.0.2.tgz 3. # cd PDO_MYSQL-1.0.2 4. # /usr/local/php/bin/phpize 如果php是yum安装的,则直接执行phpize 5. #./configure --with-php-config=/usr/bin/php-config 如果php是yum安装的就不需要 –-with...... 6. #make 7. #make install 8. 9. 修改php.ini,添加如下信息,之后重启httpd即可 10. extension = "pdo_mysql.so" 如果报错: configure: error: mysql_query missing!? 则: mkdir /usr/share/mysql/bin ln -s /usr/bin/mysql /usr/share/mysql/bin/mysql 以上两句不一定有用 ln -s /usr/lib/mysql/* /usr/local/lib/ 如果出现以下错误: 则,找一下mysql的头文件: find / -name 'mysql.h' 找到在/usr/include/mysql/中,则: ln -s /usr/include/mysql/* /usr/local/include/ ./configure --with-php-config=/usr/bin/php-config --with-pdo-mysql=/usr/share/mysql 这样configure就可以了,然后在make && make install http://192.168.0.51/test.php 之后再访问就可看到有数据了: 如果发现mysql数据库中只有nagios_开头的表,而没有npc_开头的表,请删除数据库后重新创建数据库。 重新创建数据库 mysql>drop database nagios; Create database nagios; grant all on nagios.* to ndouser@localhost identified by '111111'; GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '111111' WITH GRANT OPTION; flush privileges; quit; # cd ndoutils-1.5.2/db mysql -uroot -p nagios<mysql.sql[ align]到cacti根目录下把cacti.sql中的数据导入到数据库cacti中#cd" var="" www="" html="" cacti[="" -uroot="" -p="" nagios<cacti.sql[="" nagios="" use nagios; ALTER TABLE npc_eventhandlers ADD long_output TEXT NOT NULL DEFAULT '' AFTER output; ALTER TABLE npc_hostchecks ADD long_output TEXT NOT NULL DEFAULT '' AFTER output; ALTER TABLE npc_hoststatus ADD long_output TEXT NOT NULL DEFAULT '' AFTER output; ALTER TABLE npc_notifications ADD long_output TEXT NOT NULL DEFAULT '' AFTER output; ALTER TABLE npc_servicechecks ADD long_output TEXT NOT NULL DEFAULT '' AFTER output; ALTER TABLE npc_servicestatus ADD long_output TEXT NOT NULL DEFAULT '' AFTER output; ALTER TABLE npc_statehistory ADD long_output TEXT NOT NULL DEFAULT '' AFTER output; ALTER TABLE npc_systemcommands ADD long_output TEXT NOT NULL DEFAULT '' AFTER output; FLUSH PRIVILEGES; 如果出现不能使用默认的字符,那么将以上语句中的DEFAULT '' 删除后重新执行。 cacti npc插件使用方法 http://blog.sina.com.cn/s/blog_61c07ac50101efgd.html 1、安装步骤就不在这里赘述了,网上一搜一大把。 2、今天主要的是讲怎么使用这个npc插件的问题 cacti绘图实例要引用绘图模版,绘图模版要引用数据模版,数据模版要引用数据输入方法。所以我们先从添加数据输入方法Data Input Method开始。
点services,可以看到nagios里定义的所有服务。在想要取数据绘图的服务上双击或点右键选Service Detail。
在上面右边有个Data Input Method标签,点一下,OK。这样就往cacti里引入了一条数据输入脚本。这里以一台名称为node7主机上的检查cpu负载服务为例。好了,npc标签要做的就没有了。下面转到console标签。
点下Data Input Methods,可以看到刚才添加的cacti数据输入方法“NPC - Perfdata - node7: Current Load”在列表里了。点一下”NPC - Perfdata - node7: Current Load“,可以看它的属性
可以看到它的Input Type为Script/Command,一般的cacti数据输入都是通过snmp的,这里则是通过执行脚本来读取的。下面显示是执行perfdata.php脚本文件,参数为 --type=service --id=14。npc插件把nagios的每个服务都编了号,我这个node7主机check_load服务被编到14号。下面Output Fields栏显示的是这个输入方法定义的输出字段名,待会儿要定义的数据模版就要引用这些字段。(这里npc 有个bug,点开load5和load15。“Field [Output]”的值" load5"或" load15"前面多了个空格,把空格去掉,不然后来取不到5分钟和15分钟的数据)好了,现在点击左侧菜单Data Templates,开始添加数据模版。
这里cacti自带的模版当然没有从npc取数据的。我们要添加一个,点右上方Add,也可以右下方Choose a action auplicate复制一个已有的来修改。我复制了一个Unix - Load Average,因为跟我的cpu负载检查服务比较接近,只要改一下输入方法Data Input Method就好了。
修改模版名,我改成了npc - Unix - Load Average。把Data Input Method从Unix - Get Load Average改成前面定义的NPC - Perfdata - node7:Current Load。
下面已经有了三个Data Source Item,load_1min;load_5min;load_15min。如果刚才模版不是复制的,而是添加的,就要手动建立三个。把这三个Data Source Item项,下面Output Field选成相应的先前数据输入方法里的字段。比如load_1min的Output Field要选成load1 - load1,不然绘出来的图数据不正确。好了,数据模版完成了,再左侧点开Graph Templates开始建立绘图模版。
跟刚才一样,绘图模版也可以自己新建或是复制一个已有的模版来修改。我复制了一个Unix - Load Average来修改。改模版名为npc - Unix - Load Average。
首先来看中间有三项Graph Item Inputs,1 Minute Data Source;5 Minute Data Source;15 Minute Data Source。这是绘图的三个输入数据项名称。每个数据项又是引用的上面Graph Item中的某项。点开1 Minute Data Source
可以看到是引用了刚才Graph Item栏中的哪几项,1 Minute Data Source是引用了Graph Item中Item # 1和Item # 2的数据。回到刚才的页面。
点开Graph Item栏中的Item # 1
把Data Source数据源改成先前在数据模版中定义Data Source Item项,因为Item # 1是被1 Minute Data Source引用,1 Minute Data Source很明示是绘图时显示1分钟内负载的数据,所以Item # 1就选npc - Unix - Load Average - (load 1min)。刚才Graph Item Inputs项1 Minute Data Source中也包括了Item # 2,所以Item # 2的Data Source Item也选npc - Unix - Load Average - (load 1min)
接下来就是cacti的常规操作了。添加设备,我添加了跟刚才服务一致的主机node7,建立绘图时选择刚才建立的npc - Unix - Load Average绘图模版。这时候还看不到图表的,我这张截图是后来截的。
把绘图添加到Graph Trees。数分钟后就可以看到图表了
如果没有,看看rra目录权限有没有问题。或者直接用npc的那个脚本看能不能获取数据。在Data Input Methods里点开自己定义的数据输入方法,可以查到npc里自己这个服务的编号。然后用php -q 路径/perfdata.php --type=service --id=服务编号,查看能不能获取到数据
|