今天開始研究下Zabbix,使用Zabbix的目的,是為了能夠更好的監控mysql數據庫服務器,並且能夠生成圖形報表,雖然Nagios也能夠生成圖形報表,但沒有Zabbix這麽強大。
首先,我們先來介紹下Zabblx:
壹.Zabbix簡介
zabbix是壹個基於WEB界面的提供分布式系統監視以及網絡監視功能的企業級的開源解決方案。
zabbix由zabbix server與可選組件zabbix agent兩部門組成。
zabbix server可以通過SNMP,zabbix agent,ping,端口監視等方法提供對遠程服務器/網絡狀態的監視。
zabbix agent需要安裝在被監視的目標服務器上,它主要完成對硬件信息或與操作系統有關的內存,CPU等信息的收集。
zabbix的主要特點:
- 安裝與配置簡單,學習成本低
- 支持多語言(包括中文)
- 免費開源
- 自動發現服務器與網絡設備
- 分布式監視以及WEB集中管理功能
- 可以無agent監視
- 用戶安全認證和柔軟的授權方式
- 通過WEB界面設置或查看監視結果
- email等通知功能
等等
Zabbix主要功能:
- CPU負荷
- 內存使用
- 磁盤使用
- 網絡狀況
- 端口監視
- 日誌監視
官方也提供了安裝資料:/wiki/howto/monitor
二.Zabbix安裝
2.1 zabbix WEB環境搭建
zabbix的安裝需要LAMP或者LNMP環境。
需要其它的軟件包
yum install mysql-dev gcc net-snmp-devel curl-devel perl-DBI php-gd php-mysql php-bcmath php-mbstring php-xm
2.2 zabbix 數據庫設置
zabbix數據庫可以和zabbix服務器分離,采用用專門的mysql服務器存儲數據,此時要給zabbix數據庫受相應的權限。
grant all privileges on zabbix.* to zabbix_user@'ip' identified by '123456';
註:ip為zabbix服務器的IP地址。
關於數據庫的安裝,可以查看Mysql安裝,我習慣使用二進制包。
啟動數據庫
/usr/local/mysql/bin/mysqld_safe --user=mysql &
登錄數據庫,創建帳號和設置權限:
mysql> use mysql;
mysql>create database zabbix character set utf8;
mysql>grant all privileges on zabbix.* to zabbix_user@'192.168.10.197' identified by '123456';
2.3安裝zabbix服務
增加zabbix用戶和組
#groupadd zabbix
#useradd -g zabbix -m zabbix
官網下載解壓軟件包。
下載地址:
/download.php
#wget -snmp --with-libcurl --enable-server --enable-agent --enable-proxy
編譯報錯checking for main in -lmysqlclient ... no
yum 安裝mysql-devel即可
#make
#make install
添加服務端口
vim /etc/services
zabbix-agent 10050/tcp # Zabbix Agent
zabbix-agent 10050/udp # Zabbix Agent
zabbix-trapper 10051/tcp # Zabbix Trapper
zabbix-trapper 10051/udp # Zabbix Trapper
添加配置文件
# mkdir -p /etc/zabbix
# cp -r zabbix-2.203/conf/* /etc/zabbix/
# chown -R zabbix:zabbix /etc/zabbix
修改server配置文件,添加zabbix數據庫密碼
vim /etc/zabbix/zabbix_server.conf
LogFile=/tmp/zabbix_server.log
PidFile=/tmp/zabbix_server.pid
DBName=zabbix
DBUser=zabbix_user
DBPassword=123456 #指定zabbix數據庫密碼
ListenIP=192.168.10.197 #服務器IP地址
修改Agentd配置文件,更改HOSTNAME為本機的hostname
vim /etc/zabbix/zabbix_agentd.conf
PidFile=/tmp/zabbix_agentd.pid #進程PID
LogFile=/tmp/zabbix_agentd.log #日誌保存位置
EnableRemoteCommands=1 #允許執行遠程命令
Server=192.168.10.197 #agent端的ip
Hostname=client1 #必須與zabbix創建的host name相同
如圖設置hostname
添加web前段php文件
# cd zabbix-2.203/frontends/
# cp -rf php /home/httpd/zabbix #虛擬主機目錄
# chown -R zabbix:zabbix zabbix
web前端安裝配置
修改PHP相關參數
vim php.ini
max_execution_time = 300
max_input_time = 300
memory_limit = 128M
post_max_size = 32M
date.timezone = Asia/Shanghai
mbstring.func_overload=2
PHP還必須支持壹下模塊,在php源碼包直接編譯安裝。詳細模塊需要在安裝是會提示。
bcmath.so、gettext.so
在客戶端瀏覽器上面訪問zabbix,開始WEB的前端配置,http://ZabbixIP/zabbix,按提示點擊下壹步
Step1:下壹步。
Step2:如果全部OK的話才能進行下壹步的安裝,如果有錯誤請返回到server端檢查相關的軟件包是否安裝。
Step3:需要輸入mysql數據庫帳號密碼,如果數據庫不在zabbix服務器上面,在Host裏面添加數據庫服務器的地址,並且要用grant命令給數據庫授權。
Step4:輸入服務器端 host name or host IP addres;
最後會自動寫入配置文件:zabbix.conf.php,配置完成後出現登陸界面,默認的用戶名為:admin,密碼為:zabbix。
三.啟動zabbix服務
在zabbix安裝目錄下面可以直接啟動
#/usr/local/zabbix/sbin/zabbix_server start
tcp 0 0 0.0.0.0:10050 0.0.0.0:* LISTEN 7140/zabbix_agentd
四.設置開啟自動啟動
vim /etc/rc.d/rc.local 最後添加下面兩行
/usr/local/zabbix/sbin/zabbix_server start
/usr/local/zabbix/sbin/zabbix_agentd start
至此,zabbix server端的安裝完畢,我們可以通過瀏覽器來訪問。如圖:
接下來會介紹關於客戶端監控的使用,以及監控模版的新建,自定義監控服務等。