cacti系列(一)之cacti的安装及配置监控mysql服务

时间:2022-03-21 14:33:10

简介

Cacti是通过 snmpget来获取数据,使用 RRDtool绘画图形,而且你完全可以不需要了解RRDtool复杂的参数。它提供了非常强大的数据和用户管理功能,可以指定每一个用户能查看树状结构、host以及任何一张图,还可以与LDAP结合进行用户验证,同时也能自己增加模板,功能非常强大完善。界面友好。   





CACTI 软件 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),它能够存储的数据笔数在创建时就已经定义。关于RRDTool的知识请参阅RRDTool教学。

Cacti的官方网站:http://www.cacti.net 





1.关闭防火墙和selinux

#service iptables stop     //关闭防火墙服务

#chkconfig iptables off    //永久性关闭

#vi /etc/sysconfig/selinux   //把SELINUX=enforcing改为SELINUX=disabled



2.yum设置及时间同步



3.安装cacti依赖的软件

yum -y install mysql mysql-server mysql-devel httpd php php-pdo php-snmp php-mysql lm_sensors net-snmp net-snmp-utils net-snmp-libs rrdtool rrdtool-devel perl-PlRPC perl-DBI perl-rrdtool perl-DBD-MySQL



4:装好依赖软件之后,snmp有3个地方需要配置一下(对服务器本身进行监控)



vim /etc/snmp/snmpd.conf

第41行:将 com2sec notConfigUser default public 中的 "default" 改为 "127.0.0.1"

第62行:将 access notConfigGroup "" any noauth exact systemview none none 中的 "systemview" 改为 "all"

第85行:将 #view all include .1 80 这一行前面的 # 号去掉



5:配置好snmp以后我们来启动3个重要的服务



service snmpd start    //启动snmp服务

chkconfig snmpd on     //设置开机启动

service httpd start

chkconfig httpd on

service mysqld start

chkconfig mysqld on





6:安装并配置cacti

获取cacti主文件

http://www.cacti.net/downloads/cacti-0.8.8b.tar.gz 

tar -zxvf cacti-0.8.8b.tar.gz

mv cacti-0.8.8b /var/www/html/cacti    //将cacti-0.8.8b文件夹移到/var/www/html目录下,并将cacti-0.8.8b重命名为cacti





7:设置mysql数据库





[iyunv@Cacti ~]#mysql -uroot -p     //新装的mysql没有密码,直接回车进入mysql数据库

mysql>create database cacti;   //首先创建cacti数据库,注意别丢了分号

mysql>grant all privileges on cacti.* to cacti@localhost identified by 'cacti' with grant option;    //创建cacti用户并授权

mysql>use cacti;

mysql>source /var/www/html/cacti/cacti.sql;    //导入cacti数据库文件

mysql>exit





8:配置cacti



[iyunv@Cacti ~]#vim /var/www/html/cacti/include/config.php

$database_type = "mysql";

$database_default = "cacti";

$database_hostname = "localhost";

$database_username = "cactiuser";    //因为我们先前在数据库建的是 "cacti" 用户,所以这里默认的 "cactiuser" 要改为 "cacti"

$database_password = "cactiuser";    //这里默认的密码我们也要改为 "cacti"

$database_port = "3306";



9:增加 cacti 用户以用来写入rrd和log目录的数据,否则就会生成不了图片



useradd cacti

cd /var/www/html/cacti

chown -R cacti.cacti rra/ log/



10:添加任务计划



具体多长时间让cacti生成一次监控图表自己决定,这里以cacti的默认时间5分钟生成一次为例

[iyunv@Cacti ~]#crontab -e

加入这一行保存即可

*/5 * * * * php /var/www/html/cacti/poller.php > /dev/null 2>&1



# 如果暂时未看到图表,可以手工执行,生成图表

php /var/www/html/cacti/poller.php > /dev/null 2>&1



11:配置好之后重启输入 http://ip/cacti,如下图所示,next...

cacti系列(一)之cacti的安装及配置监控mysql服务

cacti系列(一)之cacti的安装及配置监控mysql服务

此处如果没有红色字体"NOT FOUND"字样则算通过,finish即可,如果有则要手动指定路径

finish之后就出现cacti的登录界面,默认用户名和密码都是admin

cacti系列(一)之cacti的安装及配置监控mysql服务

如果图片出现无法显示的情况,直接重启httpd服务即可



配置被监控端centos



# yum -y install net-snmp

# vim /etc/snmp/snmpd.conf

# vim /etc/snmp/snmpd.conf

1) 查找以下代码:

# sec.name        source                                        community

com2sec                notConfigUser                default        public

将"comunity"字段改为你要设置的密码.比如"public"

将“default”改为你想哪台机器可以看到你的snmp信息,如192.168.0.8

修改后:com2sec notConfigUser  192.168.0.8       public





2) 查找以下代码:



access  notConfigGroup ""  any  noauth  exact  systemview none none

将"systemview "字段改为all.

修改后:access  notConfigGroup ""  any   noauth  exact  all none none



cacti系列(一)之cacti的安装及配置监控mysql服务

cacti常用插件安装

要安装别的插件前,先要安装cacti的一个patch--Plugin Architecture,才能支持插件

下载地址:http://www.cacti.net/downloads/pia/cacti-plugin-0.8.7h-PA-v3.0.tar.gz



tar xvf cacti-plugin-0.8.7h-PA-v3.0.tar.gz

cp -R cacti-plugin-arch/* /var/www/html/cacti/

cd /var/www/html/cacti/

patch -p1 -N < cacti-plugin-0.8.7h-PA-v3.0.diff



vi include/config.php

启用配置,将注释//去掉

$url_path = “/cacti/”;

登陆,启用PA。启用方法见后图





tar zxvf monitor-v1.3-1.tgz 

mv monitor/ /var/www/html/cacti/plugins/monitor

cd /var/www/html/cacti/plugins/monitor/

登陆安装启用对应的插件即可。

启用PA以及监控插件的方法:

cacti系列(一)之cacti的安装及配置监控mysql服务

cacti系列(一)之cacti的安装及配置监控mysql服务

使用脚本监控相关软件——使用脚本监控MySQL

(1)脚本下载以及设置

wget http://mysql-cacti-templates.googlecode.com/files/better-cacti-templates-1.1.8.tar.gz

tar zxvf better-cacti-templates-1.1.8.tar.gz

cd better-cacti-templates-1.1.8

cp scripts/ss_get_mysql_stats.php /var/www/html/cacti/scripts/

我们这只测试mysql,mysql相关的有2个文件:

模板文件:./templates/cacti_host_template_x_mysql_server_ht_0.8.6i-sver1.1.8.xml

插件:./scriptsss_get_mysql_stats.php

修改ss_get_mysql_stats.php 文件



 vim /var/www/html/cacti/scripts/ss_get_mysql_stats.php

cacti系列(一)之cacti的安装及配置监控mysql服务

(2)创建监控Mysql需要的账户以及权限

配置MySQL服务器,让cacti所在机器能够访问MySQL服务器的状态信息,必须拥有”process”权限。如果要监控InnoDB状态,还必须有”SUPER”权限。

mysql> grant process,super on *.* to 'cacti'@'192.168.%.%' identified by 'cacti';

mysql> grant all privileges on cacti.* to cacti@'192.168.%.%' identified by 'cacti';





(3)模板导入

我们将模板从Linux中载下来/root/better-cacti-templates-1.1.8/templates/,进入浏览器,手动导入文件

在cacti管理界面(Import Templates)导入cacti_host_template_x_mysql_server_ht_0.8.6i-sver1.1.8.xml

cacti系列(一)之cacti的安装及配置监控mysql服务