centos shell編程6一些工做中實踐腳本 nagios監控腳本 自定義zabbix腳本 mysql備份腳本 zabbix錯誤日誌 直接送給bc作計算 gzip innobackupex/Xtrabackup 第四十節課html
上半節課
nagios監控腳本
自定義zabbix腳本mysql
下半節課
mysql備份腳本
zabbix錯誤日誌
直接送給bc作計算
gzip
innobackupex/Xtrabackuplinux
一. 自定義nagios監控腳本
nagios:0成功, 1有問題 warning, 2 嚴重 critical危險的
nagios監控
exit 0 ok,1 warning,2 criticalios
數組賦值
sta=(1 2 0 2)
數組元素讀取
${sta[0]} 從0開始web
1. 在客戶端上建立腳本/usr/local/nagios/libexec/check_disk.sh
vim /usr/local/nagios/libexec/check_disk.sh 寫入以下內容:(client上)sql
#!/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 # 加入以下內容:shell
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腳本
UserParameter=my.net.if[*],/usr/local/sbin/zabbix/net.sh $1 $2 有參數傳入就必定要加[*] (若是有多個自定義監控項就添加多個UserParameter)編程
1. 在客戶端修改配置文件 /etc/zabbix/zabbix_agentd.conf
須要改動兩個地方:
(1) UnsafeUserParameters=1
(2) UserParameter=my.net.if[*],/usr/local/sbin/zabbix/net.sh $1 $2 //其中UserParameter用來自定義鍵值key,(相似於net.if.in),本身寫的腳本每每會有參數,因此須要加[*],這是固定寫法,若是腳本壓根就沒有什麼參數,那麼這個[*]就省了。逗號後面就是咱們寫的腳本的路徑了,再後面就是要用到的參數,有幾個就寫幾。vim
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 $1}'|cut -d: -f2` 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 $1}'|cut -d: -f2>>/tmp/neti.log elif [ $2 == "out" ] then n_new=`grep "$eth" $net_file|awk '{print $9}'` 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 $9}'>>/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. 檢查腳本是否可用
在客戶端執行
/etc/init.d/zabbix-agentd restart
在服務端執行
zabbix_get -s 192.168.31.166 -p10050 -k "my.net.if[eth0,out]"
5. 若是能夠返回數值說明沒問題了,接着在瀏覽器裏面配置
組態 --> 主機 --> 項目 --> 建立兩個監控項in 和out
名稱 「網卡流量出入」
類型默認「zabbix代理」
鍵值 輸入 "my.net.if[eth0,in]"
數據更新間隔 30
存檔
名稱 「網卡流量出」
類型默認「zabbix代理」
鍵值 輸入 "my.net.if[eth0,out]"
數據更新間隔 30
存檔
監控-》最新數據-》host166
檢查是否有最新數據,是否有最新配置項
三. 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如何安裝 [url]http://www.apelearn.com/bbs/thread-1012-1-1.html[/url]
一、有沒有安裝過mysql 查找一下有沒有ibdata1這個文件
find / -name "ibdata1" -type f
yum 安裝mysql的時候看一下有沒有殘留的mysql文件,find / -name "ibdata1" -type f
若是有,先rm刪除它,再從新yum安裝mysql
二、zabbix錯誤日誌
less /var/log/zabbix/zabbix_server.log
三、直接送給bc作計算
echo "$n/$d"|bc
echo "$n-$d"|bc
echo "$n+$d"|bc
四、gzip
gzip -f 選項強制覆蓋
gzip -f 1.txt
d=$(date -d "-1day" +"%F-%T")
echo 22> /tmp/1232_$d.txt | gzip -f
五、innobackupex/Xtrabackup
innobackupex包含Xtrabackup
innobackupex能夠備份myisam和innodb
Xtrabackup 只能備份innodb
mysqldump 加 --single-transaction 選項 備份innodb表 不鎖表
f