cacti的安裝與注意事項

cacti的介紹

     

    Cacti是一套基於PHP,MySQL,SNMP及RRDTool開發的網絡流量監測圖形分析工具。

    簡單的說Cacti 就是一個PHP 程序。它通過使用SNMP 協議獲取遠端網絡設備和相關信息,(其實就是使用Net-SNMP 軟件包的snmpget 和snmpwalk 命令獲取)並通過RRDTOOL 工具繪圖,通過PHP 程序展現出來。我們使用它可以展現出監控對象一段時間內的狀態或者性能趨勢圖。

   Mysql配合PHP程序存儲一些變量數據並對變量數據進行調用,如:主機名、主機ip、snmp團體名、端口號、模板信息等變量。

    snmp抓到數據不是存儲在mysql中,而是存在rrdtool生成的rrd文件中(在cacti根目錄的rra文件夾下)。rrdtool對數據的更新和存儲就是對rrd文件的處理,rrd文件是大小固定的檔案文件(Round  Robin Archive),它能夠存儲的數據筆數在創建時就已經定義

 

Cacti 架構概述


wKiom1b4hhqSRAR0AAFyrcdz8Rw709.png


通過上圖我們可以發現Cacti 有三大組件:MySQL 數據庫、RRDtool 工具、Net-Snmp 程序。MySQL並不負責監控數據的存儲,只保存模板和rra 文件與主機對應等信息,而真正的監控數據存儲和圖像展現都是rrdtool 來做的。而Net-SNMP 負責數據的採集。


SNMP協議


SNMP(Simple Network Management Protocol)簡單網絡管理協議。是由互聯網工程任務組(IETF:Internet Engineering Task Force )定義的一套網絡管理協議。該協議基於簡單網關監視協議(SGMP:Simple Gateway Monitor Protocol)。利用SNMP,一個管理工作站可以遠程管理所有支持這種協議的網絡設備,包括監視網絡狀態、修改網絡設備配置、接收網絡事件警告等。SNMP 採用了Client/Server 模型的特殊形式:代理/管理站模型。對網絡的管理與維護是通過管理工作站與SNMP 代理間的交互工作完成的。每個SNMP 從代理負責回答SNMP 管理工作站(主代理)關於MIB 定義信息的各種查詢。


Net-snmp 的安裝包如下,前兩個包net-snmp,net-snmp-libs是基本的net-snmp 的包,net-snmp-utils 是一些工具。


RRDTool工具


RRDTool 是由Tobias Oetiker 開發的開源軟件,它使用RRD(Round Rebin Databases)作爲存儲格式,Round robin 是一種處理定量數據以及當前元素指針的技術,RRDTool 主要用來跟蹤對象的變化情況,生成改對象變化的趨勢圖。



前期準備工作:

      

Cacti官網:http://www.cacti.net/download_cacti.php

找到Linux/Unix in tar.gz   format連接圖標,

下載地址: http://www.cacti.net/downloads/cacti-0.8.8g.tar.gz

下載地址:  http://www.cacti.net/downloads/spine/cacti-spine-0.8.8b.tar.gz
確保前期安裝需要準備的軟件:

  • net-snmp-devel

  • mysql

  • mysql-devel

  • openssl-devel


如果需要源碼安裝可以從以下地址進行安裝:

    Apache     http://www.apache.org/

Mysql       http://www.mysql.com/

Php        http://www.php.net

Rrdtool     http://oss.oetiker.ch/rrdtool/

Net-snmp    http://www.net-snmp.org/

Cacti       http://www.cacti.net/

我這邊的apache、mysql、php通過yum安裝


下面簡述安裝過程:

一、安裝RRDTool和SNMP

1 安裝RRDTool
yum  -y install rrdtool
啓動rrdtool服務並且加入啓動列表
service  rrdcached start  失敗報錯:rrdcached:  未被識別的服務
chkconfig  rrdcached on 失敗

wget  http://oss.oetiker.ch/rrdtool/pub/rrdtool-1.4.8.tar.gz

也chkconfig失敗


2 安裝snmp支持工具

可以yum安裝,也可以源碼安裝,比如

Wget http://sourceforge.net/projects/net-snmp/files/net-snmp/5.6.2.1/net-snmp-5.6.2.1.tar.gz/download

 yum  -y install net-snmp
 yum -y install net-snmp-utils
啓動snmpd服務並且加入啓動列表
 service  snmpd start
 chkconfig snmpd on

3 安裝LAMP

[root@cacti ~]# yum -y install httpd mysql-server php php-mysql  mysql-devel

[root@cacti ~]# chkconfig httpd on

[root@cacti ~]# chkconfig mysqld on

[root@cacti ~]# /etc/init.d/httpd start

[root@cacti ~]# /etc/init.d/mysqld start


二、然後下載cacti
到這裏去下載 wget  http://www.cacti.net/downloads/cacti-0.8.8g.tar.gz

下載當前最新版 wget   http://www.cacti.net/downloads/spine/cacti-spine-0.8.8g.tar.gz

和cacti-spine,http://www.cacti.net/downloads/spine/

下載當前最新版 cacti-spine,wget http://www.cacti.net/downloads/spine/cacti-spine-0.8.8g.tar.gz


三、開始安裝cacti-spine

1,建立cacti用戶

[root@squid-2 ~]# useradd -m cacti

[root@squid-2 ~]# passwd cacti

密碼:cacti

2,首先安裝幾個編譯cacti-spine需要的devel:
yum install net-snmp-devel -y
yum install  mysql-devel -y
yum install openssl-devel  -y

3,安裝gcclibtool
yum install gcc -y
yum install libtool  -y


4,下載cactid並解壓:
tar -xf  cacti-spine-0.8.8g.tar.gz
編譯安裝:
cd  cacti-spine-0.8.8g
aclocal
libtoolize --force
autoheader
autoconf
automake
./configure
make
make  install


5,安裝好以後,我們需要再配置一下:

vim /etc/spine.conf
DB_Host  localhost
DB_Database cacti
DB_User cacti_user
DB_Pass  cacti05261743
DB_Port 3306,


6,啓動一下看看

#/usr/local/spine/bin/spine

一般顯示類似以下的內容

SPINE: Using spine config file [/etc/spine.conf]
SPINE: Version  0.8.8a starting
SPINE: Time: 0.1190 s, Threads: 5, Hosts:  2


7,創建mysql賬號:


mysql> set names utf8;

Query OK, 0 rows affected (0.00 sec)

mysql> create database cacti;

Query OK, 1 row affected (0.09 sec)

mysql>

mysql> grant all on cacti.* to cacti_user@\


登錄mysql,刪除掉’’@localhost以及’’@hostname2個用戶名爲空串的mysql賬號,就OK了。



[cacti@squid-2 ~]$ /usr/local/spine/bin/spine

SPINE: Using spine config file [/etc/spine.conf]

MYSQL: Connection Failed: Error:\'2002\', Message:\'Can\'t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock\' (2)\'

MYSQL: Connection Failed: Error:\'2002\', Message:\'Can\'t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock\' (2)\'

MYSQL: Connection Failed: Error:\'2002\', Message:\'Can\'t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock\' (2)\'

MYSQL: Connection Failed: Error:\'2002\', Message:\'Can\'t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock\' (2)\'

MYSQL: Connection Failed: Error:\'2002\', Message:\'Can\'t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock\' (2)\'

05/16/2014 04:11:43 PM - SPINE: Poller[0] FATAL: Connection Failed, Error:\'2002\', Message:\'Can\'t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock\' (2)\' (Spine init)


找到正在運行的mysql.sock的路徑,做一個軟連接:


[root@mysqlvm2 bin]# find / -name mysql.sock

/usr/local/mysql/mysql.sock

[root@mysqlvm2 bin]#

[root@mysqlvm2 bin]# ln -s /usr/local/mysql/mysql.sock /var/lib/mysql/mysql.sock

[root@mysqlvm2 bin]#


再次啓動,有報錯如下:


[root@mysqlvm2 bin]# /usr/local/spine/bin/spine

SPINE: Using spine config file [/etc/spine.conf]

05/16/2014 04:16:40 PM - SPINE: Poller[0] FATAL: MySQL Error:\'1146\', Message:\'Table \'cacti.settings\' doesn\'t exist\


需要導入默認的cacti.sql,解壓縮.tar.gz,獲得cacti.sql


[cacti@squid-2 cacti-0.8.8b] tar -xvf cacti-0.8.8b.tar.gz

[cacti@squid-2 cacti-0.8.8b] cd cacti-0.8.8b

[root@mysqlvm2 bin]# type mysql

mysql is hashed (/usr/local/mysql/bin/mysql)

[cacti@squid-2 cacti-0.8.8b]$mysql -u cacti_user -pcacti05261743 -h127.0.0.1 cacti </home/cacti/cacti-0.8.8b/cacti.sql

[cacti@squid-2 cacti-0.8.8b]$ /usr/local/spine/bin/spine

SPINE: Using spine config file [/etc/spine.conf]

SPINE: Version 0.8.8b starting

SPINE: Time: 0.1386 s, Threads: 5, Hosts: 2

[cacti@squid-2 cacti-0.8.8b]$


啓動成功了。

8,最後,等cacti安裝完之後在cacti的web配置界面選擇setting 

settings->paths->Spine Poller File Path  [/usr/local/spine/bin/spine]
settings->poller->Poller Type  [spine]
console->settings->poller->Maximum Threads  per Process [5]
save完成。


四、我們開始安裝正主cacti

1 配置

解壓並放到apache文檔目錄(/var/www/html)
 tar -xf cacti-0.8.8b.tar.gz
  mv cacti-0.8.8b  /var/www/html/cacti

cd /var/www/html/


編輯CentOS cacti配置文件,連接MySQL服務的用戶名,密碼,端口等。


vim /var/www/html/cacti/include/config.php

#

 $database_type = \"mysql\";

$database_default = \"cacti\";

$database_hostname = \"localhost\";

$database_username = \"cacti_user\";

$database_password = \"cacti_user05161610\";

$database_port = \"3306\";

$database_ssl = false;




2添加計劃任務(使cacti5分鐘獲得一次數據)
#crontab -e
*/1 * * * *  /usr/bin/php /var/www/html/cacti/poller.php > /dev/null 2>&1  //讓系統每1分鐘收集


3 數據庫配置

在前面的第三步已經配置好了,創建數據庫cacti以及用戶。


4 測試,建立一個login.jsp文件

[root@mysqlvm2 cacti]# vim login.php


simple demo


phpinfo();

?>

如下圖所示:

打開網址頁面:
啓動完httpd之後,可以打開  http://10.xx.1.xx/,界面如下:



遇到的小問題,打開index.php是空頁面,如下所示:

去查看日誌,日誌沒有任何信息:



問題在哪裏呢?

找到apache的配置文件httpd.conf

[root@mysqlvm2 www]# vim /etc/httpd/conf/httpd.conf

Search  error_log

日誌路徑 /var/log/httpd/error_log

[root@mysqlvm2 cacti]# cd /var/log/httpd/

[root@mysqlvm2 httpd]# ll

總計 20

-rw-r--r-- 1 root root 9228 05-16 18:39 access_log

-rw-r--r-- 1 root root 2049 05-16 18:14 error_log

-rw-r--r-- 1 root root    0 05-16 17:18 ssl_access_log

-rw-r--r-- 1 root root 1422 05-16 18:14 ssl_error_log

-rw-r--r-- 1 root root    0 05-16 17:18 ssl_request_log


逐個查看log信息,在ssl_error_log裏面發現錯誤信息:


[root@mysqlvm2 httpd]# tail -f ssl_error_log

[Fri May 16 18:00:36 2014] [warn] RSA server certificate is a CA certificate (BasicConstraints: CA == TRUE !?)

[Fri May 16 18:00:36 2014] [warn] RSA server certificate CommonName (CN) `localhost.localdomain\' does NOT match server name!?

[Fri May 16 18:14:39 2014] [warn] RSA server certificate is a CA certificate (BasicConstraints: CA == TRUE !?)

[Fri May 16 18:14:39 2014] [warn] RSA server certificate CommonName (CN) `localhost.localdomain\' does NOT match server 

[Fri May 16 18:14:39 2014] [warn] RSA server certificate is a CA certificate (BasicConstraints: CA == TRUE !?)

[Fri May 16 18:14:39 2014] [warn] RSA server certificate CommonName (CN) `localhost.localdomain\' does NOT match server name!?

[Fri May 16 18:48:48 2014] [warn] RSA server certificate is a CA certificate (BasicConstraints: CA ==TRUE !?)

[Fri May 16 18:48:48 2014] [warn] RSA server certificate CommonName (CN) `localhost.localdomain\'does NOT match server 

[Fri May 16 18:48:48 2014] [warn] RSA server certificate is a CA certificate (BasicConstraints: CA == TRUE !?)

[Fri May 16 18:48:48 2014] [warn] RSA server certificate CommonName (CN) `localhost.localdomain\


經過朋友的提醒,還需要安裝php-mysql組件

[root@mysqlvm2 httpd]# yum install -y php-mysql

之後,再打開頁面,http://10.254.1.12/cacti/install/,就有信息如下:


點擊next,繼續下一步,其他的都死默認選項,默認登錄用戶名密碼是admin:



五:Cacti監控mysql報表流量圖:

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

tar –xvf better-cacti-templates-1.1.8.tar.gz

cd better-cacti-templates-1.1.8

better-cacti-templates-1.1.8\scripts下的 ss_get_mysql_stats.php 這個腳本 這個腳本需要放在cacti的服務端。

比如cacti部署在/var/www/html目錄下,那麼就cp/var/www/html/cacti/scripts/

cp /root/better-cacti-templates-1.1.8/scripts/ss_get_mysql_stats.php /var/www/html/cacti/scripts/

修改ss_get_mysql_stats.php 文件 第30

$mysql_user = 'cacti_user'; 
$mysql_pass = 'cacti_user05161610'; 
$cache_dir = "/xok.la/cacti/cache/"; 

chown -R apache.apache /var/www/html/cacti/scripts

chmod -R 755 /var/www/html/cacti/scripts

使用 http 訪問 cacti主機 導入

/opt/mysql-cacti-templates-1.1.2/cacti_host_template_x_db_server_ht_0.8.6i.xml 

然後創建mysql用戶:

grant process,super on *.* to 'cacti_user'@'%' identified by 'cacti_user05161610'; 


本文轉自:http://blog.itpub.net/26230597/viewspace-1170579/

        http://www.linuxidc.com/Linux/2012-07/66918.htm



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章