nagios和zabbix自定義監控腳本


一. 自定義nagios監控腳本

1. 在客戶端上創建腳本/usr/local/nagios/libexec/check_disk.sh
vim  /usr/local/nagios/libexec/check_disk.sh 寫入如下內容:(client上)
#!/bin/bash
#!/bin/bash
row=`df -h |wc -l`
for i in `seq 2 $row`
do
        ava=`df -h |sed -n "$i"p|awk '{print $4}'`
        u_per=`df -h |sed -n "$i"p|sed -n "s/\%//"p|awk '{print $5}'`
        p_p=`df -h -P|sed -n "$i"p|awk '{print $6}'`
        if [ "$u_per" -gt "97"  ];then
                echo -n "$p_p CRITICAL $u_per% $ava  "
                sta[$i]=2
        elif [ "$u_per" -gt "95" ];then
                echo -n "$p_p WARNING! $u_per% $ava  "
                sta[$i]=1
        else
                echo -n "$p_p OK $u_per% $ava  "
                sta[$i]=0
        fi
done
n=0
for j in `seq 2 $row`
do
        if [ "${sta[$j]}" -gt $n  ];then
                n=${sta[$j]}
        fi
done
exit $n

2. 保存后,修改該腳本的權限
chmod +x  /usr/lib/nagios/plugins//check_disk.sh (client上)
3. 然后編輯/etc/nagios/nrpe.cfg文件
vim /etc/nagios/nrpe.cfg  # 加入一行:(client上)
command[check_disk]=/usr/lib/nagios/plugins/check_disk.sh
保存,重啟nrpe服務
/etc/init.d/nrpe restart (client上)
4. 檢測剛才的腳本是否正常運行的方法是,到server端執行如下命令:
check_nrpe -H 192.168.0.12 -c check_disk (server上)
如果正常的話,會輸出一行磁盤檢測的數據,否則可能會報錯。
5. 到server上添加相應的service
cd /etc/nagios/conf.d/
vim 192.168.0.12.cfg     # 加入如下內容:
define service{
        use     generic-service
        host_name       192.168.0.12
        service_description     check_disk
        check_command           check_nrpe!check_disk
        max_check_attempts 5
        normal_check_interval 1
}
6. 重啟nagios服務
/etc/init.d/nagios restart   (server上)

二. 自定義zabbix腳本
1.  在客戶端修改配置文件  /etc/zabbix/zabbix_agentd.conf
需要改動兩個地方:

  1. (1)  UnsafeUserParameters=1
  2. (2) UserParameter=my.net.if【*】(改成英文的方括號), /usr/local/sbin/zabbix/net.sh $1 $2   //其中UserParameter用來自定義鍵值,(類似於net.if.in),自己寫的腳本往往會有參數,所以需要加,這是固定寫法,如果腳本壓根就沒有什么參數,那么這個就省了。逗號后面就是我們寫的腳本的路徑了,再后面就是要用到的參數,有幾個就寫幾。


2. 編寫腳本
vi   /usr/local/sbin/zabbix/net.sh   //內容如下

#!/bin/bash
eth=$1
io=$2
net_file="/proc/net/dev"
if [ $2 == "in" ]
then
    n_new=`grep "$eth" $net_file|awk '{print $2}'`
    n_old=`tail -1 /tmp/neti.log`
    n=`echo "$n_new-$n_old"|bc`
    d_new=`date +%s`
    d_old=`tail -2 /tmp/neti.log|head -1`
    d=`echo "$d_new-$d_old"|bc`
    if_net=`echo "$n/$d"|bc`
    echo $if_net
    date +%s>>/tmp/neti.log
    grep "$eth" $net_file|awk '{print $2}'>>/tmp/neti.log
elif [ $2 == "out" ]
then
    n_new=`grep "$eth" $net_file|awk '{print $10}'`
    n_old=`tail -1 /tmp/neto.log`
    n=`echo "$n_new-$n_old"|bc`
    d_new=`date +%s`
    d_old=`tail -2 /tmp/neto.log|head -1`
    d=`echo "$d_new-$d_old"|bc`
    if_net=`echo "$n/$d"|bc`
    echo $if_net
    date +%s>>/tmp/neto.log
    grep "$eth" $net_file|awk '{print $10}'>>/tmp/neto.log
else
    echo 0
fi


這個腳本的思路,就是通過查看文件 /proc/net/dev  里面的數值,來計算實時網卡流量,其實我算的是一個平均值。分為進和出。如果這個腳本每隔1分鍾執行一次,那么算出來的流量值就是1分鍾的平均值。


3.  在腳本執行前,需要先做一個操作
touch /tmp/net[io].log
date +%s >>/tmp/neti.log
grep eth0 /proc/net/dev |awk '{print $2}' >>/tmp/neti.log
date +%s >>/tmp/neto.log
grep eth0 /proc/net/dev |awk '{print $10}' >>/tmp/neto.log
chown zabbix  /tmp/net[io].log

4. 檢查腳本是否可用
在服務端執行
zabbix_get -s 192.168.31.166 -p10050 -k "my.net.if[eth0,out]"

5. 如果可以返回數值說明沒問題了,接着在瀏覽器里面配置
組態 --> 主機 --> 項目  --> 創建監控項
名稱 “網卡流量出”
類型默認“zabbix代理”
鍵值  "my.net.if[eth0,out]"
數據更新間隔  60
存檔

三.  mysql備份腳本
1. 最簡單的
#!/bin/bash
d=`date +%w`
/usr/bin/mysqldump -umylinux -pxxxxx mylinux >/data/mysqlbak/$d.sql

2. 稍微復雜的
#! /bin/bash

STORE_NAME=`date +%m%d`
STORE_NAME2=`date +%w`
STORE_DIR='/backup/mysqlbak'
REMOTE_DIR='ypl-web:/backup'
BACKUP_DIR='/data/mysql/'
exec 1>/var/log/mysqlbak.log 2>&1
echo mysqlbak start `date`

/etc/init.d/mysqld stop
sleep 2
killall -9 mysqld; sleep 2
killall -9 mysqld
/usr/bin/rsync -azu $BACKUP_DIR $STORE_DIR/$STORE_NAME2
/etc/init.d/mysqld start

for db in ypl 1yplcc ypl913 ecshop wordpress 
do
    /usr/local/mysql/bin/mysqldump  -uroot -p'xxx' $db >$STORE_DIR/$db-$STORE_NAME.sql
echo mysqlbak end `date`

cd $STORE_DIR
for db in ypl 1yplcc ypl913 ecshop wordpress 
do
    gzip   -f  $db-$STORE_NAME.sql
done
find $STORE_DIR/*.sql.gz  -mtime +6 |xargs rm -f

echo remote bak start `date`
/usr/bin/rsync -azu --delete $STORE_DIR $REMOTE_DIR/
echo remote bak end `date`

3. innodb引擎,超大數據庫備份
#!/bin/bash
## mysql backup daily 3306 and 3307.
exec 2> /BACKUP/mysqlbackup/bak.err

innb="/usr/bin/innobackupex"
opt="--user=backup \
     --password=bakBAK001 \
     --defaults-file=/etc/my.cnf "
bakdir="/BACKUP/mysqlbackup/whole"

bak() {
    $innb $opt --socket=$1 $bakdir/$2
}

bak /tmp/mysql1.sock 3306 >/tmp/3306.bak
bak /tmp/mysql2.sock 3307 >/tmp/3307.bak

find /BACKUP/mysqlbackup/whole/ -type f -mtime +7 |xargs rm -f

innobackupex如何安裝  http://www.apelearn.com/bbs/thread-1012-1-1.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM