近期有不少同窗對nagios和cacti整合非常糾結,特寫此文方便你們參考,解決你們在nagios和cacti整合的過程當中遇到的問題。php
做爲一名Linux SA,平常最重要的就是保證網站正常穩定的運行,咱們須要實時監控網站、服務器的運行狀態,這時須要藉助開源軟件(cacti、nagios、zabbix等)監控來實現。html
Cacti是用php語言實現的一個軟件,它的主要功能是用snmp服務獲取數據,而後用rrdtool儲存和更新數據,當用戶須要查看數據的時候用rrdtool生成圖表呈現給用戶。所以,snmp和rrdtool是cacti的關鍵。mysql
Snmp關係着數據的收集,rrdtool關係着數據存儲和圖表的生成。snmp抓到數據不是存儲在mysql中,而是存在rrdtool生成的rrd文件中(在cacti根目錄的rra文件夾下,通常以rra爲後綴名稱)。簡單原理圖以下:ios
1) Cacti服務器端安裝sql
官網下載cacti相關軟件,一共須要三個軟件,下載地址分別以下:數據庫
http://www.cacti.net/downloads/cacti-0.8.8a.tar.gzapache
http://oss.oetiker.ch/rrdtool/pub/rrdtool-1.4.5.tar.gzjson
http://www.cacti.net/downloads/spine/cacti-spine-0.8.8a.tar.gz服務器
2) 安裝LAMP系統環境dom
這裏採用yum安裝方式,安裝命令:
yum install httpd mysql mysql-server php php-mysql php-json php-pdo -y
3) 安裝rrdtool採集工具
安裝rrdtool以前須要安裝相應的lib庫,以下安裝:
yum install cairo-devel libxml2-devel pango pango-devel –y
tar xzf rrdtool-1.4.5.tar.gz ;cd rrdtool-1.4.5 ; ./configure --prefix=/usr/local/rrdtool/
make &&make install ;ln -s /usr/local/rrdtool/bin/* /usr/local/bin/
4) 安裝SNMP服務
yum install net-snmp net-snmp-utils –y
5) 安裝cacti主程序
tar xzf cacti-0.8.8a.tar.gz && mv cacti-0.8.8a /var/www/html/cacti/
6) 建立cacti數據庫
mysql -uroot –p 輸入你的密碼進入數據庫,而後建立數據庫:
create database cacti;建立數據庫
grant all on cacti.* to cacti@'localhost' identified by "123456";建立用戶並受權
flush privileges; 刷新權限
mysql配置完畢後,把cacti數據導入cacti數據庫
mysql -ucacti -p123456 cacti </var/www/html/cacti/cacti.sql
配置完mysql後,咱們須要設置cacti rra、log 目錄的權限,這裏設置爲777:
chmod -R 777 /var/www/html/cacti/rra/
chmod -R 777 /var/www/html/cacti/log/
7) 修改cacti全局配置文件
vi /var/www/html/cacti/include/config.php爲以下配置:
8) 添加Rrdtool抓圖任務計劃
*/5 * * * * /usr/bin/php /var/www/html/cacti/poller.php >>/tmp/cacti_rrdtool.log 2 >&1
9) Cacti安裝完畢,測試訪問
經過http://ip/cacti/ 訪問出現以下界面,點擊NEXT下一步。
默認一直點擊下一步:
進入登陸界面,第一次須要修改密碼:
進入Cacti配置管理界面
點擊device,能夠添加設備,默承認以看到127.0.0.1這臺服務器。右上角Add能夠增長設備。
點擊localhost能夠看到具體的設置,包括採用的snmp協議版本,監控的名稱等:
若是出現snmp error,檢查snmp服務是否已啓動,或者是否有權限。出現如上信息則表示正常。
點擊左上角第二個按鈕,graphs查看cacti圖像—選擇localhost主機—右邊會顯示cacti每5分鐘的監控圖像。
更多cacti深刻知識,能夠一塊兒交流。
鑑於篇幅的問題,這裏nagios部署就略過了,有興趣的同窗能夠參考個人從入門到高級的課程哦,這裏直接講解nagios+cacti如何來整合。
首先須要安裝php json模塊和ndoutils,其中Ndoutils是nagios的一個插件,就是能夠用來把nagios的獲取的數據存入到mysql數據庫中。也能夠實現與cacti的插件npc的集成,這個工具的安裝是個關鍵。
Php-json安裝方法:
Wget http://down1.chinaunix.net/distfiles/json-1.2.1.tgz
tar xzf json-1.2.1 ;cd json-1.2.1 ;phpize ;./configure ;make ;make install
安裝完後,而後執行以下語句添加json模塊:
echo "extension=json.so" >/etc/php.d/json.ini
重啓apache服務器,通phpinfo.php頁面能夠看到以下內容便可:
安裝ndoutils:
wget http://downloads.sourceforge.net/project/nagios/ndoutils-1.x/ndoutils-1.4b9/ndoutils-1.4b9.tar.gz
tar xzf ndoutils-1.4b9.tar.gz;cd ndoutils-1.4b9 ; ./configure --with-mysql-inc=/usr/include/mysql --with-mysql-lib=/usr/lib/mysql --enable-mysql --with-ndo2db-user=nagios --with-ndo2db-group=nagios &&make &&make install
接下來配置ndoutils:
cp config/ndo2db.cfg-sample /usr/local/nagios/etc/ndo2db.cfg
cp config/ndomod.cfg-sample /usr/local/nagios/etc/ndomod.cfg
ndo2db.cfg內容以下:
ndo2db_user=nagios
ndo2db_group=nagios
socket_type=tcp
socket_name=/usr/local/nagios/var/ndo.sock
tcp_port=5668
db_servertype=mysql
db_host=localhost
db_port=3306
db_name=cacti
db_prefix=npc_
db_user=cacti
db_pass=123456
max_timedevents_age=1440
max_systemcommands_age=10080
max_servicechecks_age=10080
max_hostchecks_age=10080
max_eventhandlers_age=44640
debug_level=1
debug_verbosity=1
debug_file=/usr/local/nagios/var/ndo2db.debug
max_debug_file_size=1000000
ndomod.cfg內容以下:
instance_name=default
output_type=tcpsocket
output=127.0.0.1
tcp_port=5668
output_buffer_items=5000
buffer_file=/usr/local/nagios/var/ndomod.tmp
file_rotation_interval=14400
file_rotation_timeout=60
reconnect_interval=15
reconnect_warning_interval=15
data_processing_options=-1
config_output_options=2
同時在nagios.cfg文件最末尾添加以下語句:
broker_module=/usr/local/nagios/bin/ndomod.o config_file=/usr/local/nagios/etc/ndomod.cfg
安裝npc軟件:
wget ftp://ftp.mirrorservice.org/sites/downloads.sourceforge.net/g/gi/gibtmirdas/npc-2.0.4.tar.gz
tar xzf npc-2.0.4.tar.gz ;mv npc /var/www/html/cacti/plugins/
經過界面啓用NPC
選擇啓用,而後點擊settings,找到NPC項,填入以下內容便可。
而後後臺啓動nod2db服務:
/usr/local/nagios/bin/ndo2db -c /usr/local/nagios/etc/ndo2db.cfg
查看後臺日誌還須要在mysql裏面執行以下sql便可:
mysql> use cacti;
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;
執行成功後,重啓nagios和ndo2db便可,經過頁面刷新能夠看到以下界面即表明整合成功。