使用yum安装需要的软件包:
# yum install php php-mysql php-snmp mysql mysql-server net-snmp net-snmp-libs net-snmp-utils php-pdo perl-DBD-MySQL
在主监控机上安装rrdtool:
        需要安装rrdtool rrdtoo-devel rrdtool-php    
下载好这些软件使用:
           #yum localinstall *.rpm –nogpgcheck
配置/etc/snmp/snmp.conf文件:      
   com2secnotConfigUser default public default该用来127.0.0.1   
   access notConfigGroup "" any noauth exact systemview none none systemview该为all   
    #view all included .1 80 的‘#’去掉
          #service snmpd restart
安装 cacti 下载 cacti-0.8.7e.tar.gz
        #tar xvf cacti-0.8.7e.tar.gz
        #mv cacti-o.8.73.tar.gz /var/www/html/cacti
        #useradd cacti
        #chown –R   cacti /var/www/html/cacti
        #chmod  -R 775 /var/www/html/cacti
在数据库中配置 cacti 的访问权限:
       # service mysqld restart
      mysql> create database cacti;
      mysql> grant all privileges on cacti.* to cacti@localhost identified by 'cacti' with grant option;
      mysql> grant all privileges on cacti.* to cacti@127.0.0.1 identified by 'cacti' with grant option;
      mysql> use cacti;
      mysql> source /var/www/html/cacti/cacti.sql; 配置/var/www/html/cacti/include/config.php ,username,password该一下      
       #service httpd restart     
         #setenforce 0 如果不关闭会出现很多问题,如访问不了,没有权限等
 游览器中输入以下内容: http://192.168.0.1/cacti 会出现安装界面,ip是该服务器的ip地址,直接单击next,一路下去直到输入账户admin密码admin ,这是默认账户密码,之后会重新改密码,自己随便设置个就行了。单击graphs,你可以看本机的监控图,注意一定要有耐心,总会出现的,这个成图很慢。
创建个计划任务: crontab –u cacti –e 加入下列内容:
  */5 * * * * php /var/www/html/cacti/poller.php > /dev/null 2>&1
确保: /var/www/html/cacti/rra 存在,如果没有看到图可以手动执行一下这个计划中的命令
   php /var/www/html/cacti/poller.php > /dev/null 2>&1
25046147_1315824475jH7r.png
使用 Cacti 监控 Linux 主机
#在被监控的linux主机上安装net-snmp
                  yum install net-snmpvi
编辑 /etc/snmp/snmpd.conf文件:
将下边这行中的defaultcom2secnotConfigUser default public
   #改为192.168.0.3cacti)服务器的地址)com2secnotConfigUser 192.168.0.3 public
#将下边这行中的systemviewaccess notConfigGroup "" any noauth exact systemview none none
    #改为allaccess notConfigGroup "" any noauth exact all none none
#将下边这行的注释“#”号去掉#view all included .1 80service snmpd restart
9)如果出现问题请注意一下snmp协议的版本,都用version 1是一种解决方法如果都用version 1,需要把所有监控机和被监控机的snmpd.conf改一下
#vi /etc/snmp/snmpd.conf#将下边这行view systemview included .1.3.6.1.2.1.1
#改为view systemview included .1.3.6.1.2.1 在游览器输入服务端的http://ip/cacti 选择console--devices---add填入一下内容,这是要监控的客户端:
25046147_1315824479Jt8h.png25046147_13158244867iHn.png选择default trees-----单击default trees---add 填入一下内容即可,然后选择graphs可以看着监控的主机的图25046147_1315824489c7fZ.png
cacti 常用插件安装
      要安装别的插件前,先要安装cacti的一个patch--Plugin Architecture,才能支持插件 PA 2.8 = cacti 0.8.7g  
   # tar xvf cacti-plugin-0.8.7g-PA-v2.8.tar.gz
   # cp -R cacti-plugin-arch/* /var/www/html/cacti/ cd /var/www/html/cacti/
   #mysql -ucacti -pcacti cacti <pa.sql patch -p1 -N <cacti-plugin-0.8.7g-PA-v2.8.diff
编辑vi include/config.php 修改为$url_path = “/cacti/”;

  安装常用插件 Monitor,Settings,thold  
    # tar zxvf monitor-latest.tg z
    # tar zxvf settings-latest.tgz
    # tar zxvf thold-latest.tgz
    # mv monitor-0.9/ /var/www/html/cacti/plugins/monitor # mv settings-0.6/ /var/www/html/cacti/plugins/settings
    # mv thold-0.41/ /var/www/html/cacti/plugins/thold
     mysql -u cactiuser -p cactidb < thold/thold.sql
    mysql -u cactiuser -p cactidb < monitor/monitor.sql
    vim /var/www/html/cacti/include/config.php
       $plugins = array();
       $plugins[] = "settings";
       $plugins[] = "thold";
       $plugins[] = "monitor";
登陆安装启用对应的插件即可。   
这里以monitor为例:选择user Management --- admin –plugin management(打上钩),也将monitor打上钩


常见故障排除 安装完毕在浏览器上无法看到数据的png图片。看apachelog  
    如果出现:     ========================    
[Thu Feb 09 15:12:24 2006] [error] [client 127.0.0.1] File does not exist: /var/www/html/favicon.ico    
ERROR: opening '/var/www/html/cacti/rra/localhost_mem_buffers_3.rrd': Permission denied     PS: 解决办法:关闭selinux,即可解决问题。
  PS :以上无法获取数据图大多和poller.phpcmd.php权限有关。
   当cacti 有图没有数据时,而且状态为nan的错误
PS :这个很可能是snmp的问题,执行以下命令,没有得到如图的结果。就说明snmp不支持64MIB库。重新编译安装snmp
        # snmpwalk -c public -v 2c 127.0.0.1

   IF-MIB::ifHCInOctets IF-MIB::ifHCInOctets.1 = Counter64: 7437357 IF-MIB::ifHCInOctets.2 =   Counter64: 353773IF-MIB::ifHCInOctets.3 = Counter64: 0
PS :被监控主机无法获得snmp信息,还有可能是对方主机snmp版本和当前主机的snmp版本不一致导致的。
PS rrdtools版本要一致,特别是在升级cacti时候。版本不一致,可能rra数据格式不同。就无法处理。

排错思路 1 ,查看log下的日志文件。一般那里会有提示
2 ,测试SNMP是不是工作正常 snmpwalk -v 2c -c public hostIP   if正常的话会出现一些数据。不正常会出现一些错误,也会有对应的错误提示。
3 ,自动运行poller.php没有。有没有加入cacti的的用户。。有没有给cacti用户写入rra/ log/的权限。。
4 crontab –u cactiuser –e cactiuser加上自动运行poller.php的任务:
             */ 5     *       *       *       *       root    /usr/local/bin/php /usr/local/share/cacti/poller.php /dev/null 2>&1         5 分钟刷新一次数据。你也可以根据需要还设置。 5 。把cacti目录里的cmd.phppoller.php文件加下运行的权限。

脚本下载以及设置  

下载mysql-cacti-templates模板,用来检测mysql的状态:
wget http://mysql-cacti-templates.googlecode.com/files/mysql-cacti-templates-1.1.2.tar.gz
tar -xzvf mysql-cacti-templates-1.1.2.tar.gz
cd mysql-cacti-templates-1.1.2
cp ss_get_mysql_stats.php /var/www/html/cacti/scripts
在游览器中导入该模板文件:cacti_host_template_x_db_server_ht_0.8.6i.xml
修改ss_get_mysql_stats.php 文件
      $mysql_user = 'cacti' ;
      $mysql_pass = 'cacti';
      $cache_dir  = "var/www/html/cacti/cache/";
     #mkdir /var/www/html/cacti/cacti/cache/
     #chmod 777 -R /var/www/html/cacti/cache/
默认在获取的数据/tmp/下,会有cacti不能读取的情况。所以放在cacti目录来。  
二,创建监控Mysql需要的账户以及权限 配置MySQL服务器,让cacti所在机器能够访问MySQL服务器的状态信息,必须拥有”process”权限。如果要监控InnoDB状态,还必须有”SUPER”权限。
mysql> grant process,super on *.* to 'cacti'@'%' identified by 'cacti';
mysql> grant all privileges on cacti.*  to cacti@"%" identified by "cacti";
  选择import templates cacti_host_template_x_db_server_ht_0.8.6i.xml导入之后,选择
devices-----mylinux( 或者localhost反正是监控的机器),可以看到如图中的 带有mysql的信息,选中所需就可以监控mysql

25046147_1315824493K17I.png