工作中使用Shell實(shí)用腳本
1. 內(nèi)存監(jiān)控腳本
#!/bin/bash
#memory use
mem_war_file=/tmp/mem_war.txt
mem_use=`free -m | grep Mem | awk '{print $3}'`
mem_total=`free -m | grep Mem | awk '{print $2}'`
mem_percent=$((mem_use*100/mem_total))
# echo "$mem_percent"%
if (($mem_percent > 80));then
echo "`date +%F-%H-%M` mem: ${mem_percent}%" >$mem_war_file
echo "`date +%F-%H-%M` mem: ${mem_percent}%" | mail -s "mem warning" root
fi
2. 檢測(cè)網(wǎng)卡流量,并按規(guī)定格式記錄在日志中
#!/bin/bash
#######################################################
#檢測(cè)網(wǎng)卡流量,并按規(guī)定格式記錄在日志中
#規(guī)定一分鐘記錄一次
#日志格式如下所示:
#2021-07-08 18:55
#eth0 input: 1234bps
#eth0 output: 1235bps
######################################################3
while :
do
#設(shè)置語(yǔ)言為英文,保障輸出結(jié)果是英文,否則會(huì)出現(xiàn)bug
LANG=en
logfile=/tmp/`date +%d`.log
#將下面執(zhí)行的命令結(jié)果輸出重定向到logfile日志中
exec >> $logfile
date +"%F %H:%M"
#sar命令統(tǒng)計(jì)的流量單位為kb/s,日志格式為bps,因此要*1000*8
sar -n DEV 1 59|grep Average|grep eth0|awk '{print $2,"\t","input:","\t",$5*1000*8,"bps","\n",$2,"\t","output:","\t",$6*1000*8,"bps"}'
echo "####################"
#因?yàn)閳?zhí)行sar命令需要59秒,因此不需要sleep
done
3. 監(jiān)測(cè)Nginx訪問(wèn)日志502情況,并做相應(yīng)動(dòng)作
假設(shè)服務(wù)器為lnmp環(huán)境,近期訪問(wèn)經(jīng)常出現(xiàn)502現(xiàn)象,且502錯(cuò)誤在重啟php-fpm服務(wù)后消失,因此編寫(xiě)監(jiān)控腳本,一旦出現(xiàn)502,則自動(dòng)重啟php-fpm服務(wù)。
#場(chǎng)景: #1.訪問(wèn)日志文件的路徑:/data/log/access.log #2.腳本死循環(huán),每10秒檢測(cè)一次,10秒的日志條數(shù)為300條,出現(xiàn)502的比例不低于10%(30條)則需要重啟php-fpm服務(wù) #3.重啟命令為:/etc/init.d/php-fpm restart #!/bin/bash ########################################################### #監(jiān)測(cè)Nginx訪問(wèn)日志502情況,并做相應(yīng)操作 ########################################################### log=/data/log/access.log N=30 #設(shè)定閾值 while : do #查看訪問(wèn)日志的最新300條,并統(tǒng)計(jì)502的次數(shù) err=`tail -n 300 $log |grep -c '502" '` if [ $err -ge $N ] then /etc/init.d/php-fpm restart 2> /dev/null #設(shè)定60s延遲防止腳本bug導(dǎo)致無(wú)限重啟php-fpm服務(wù) sleep 60 fi sleep 10 done
4. 掃描主機(jī)端口狀態(tài)
#!/bin/bash HOST=$1 PORT="22 80 8080 3306" for PORT in $PORT; do if echo &>/dev/null > /dev/tcp/$HOST/$PORT; then echo "$PORT open" else echo "$PORT close" fi done
5. 檢測(cè)兩臺(tái)服務(wù)器某個(gè)目錄下的文件一致性
#!/bin/bash
#####################################
#檢測(cè)兩臺(tái)服務(wù)器指定目錄下的文件一致性
#####################################
#通過(guò)對(duì)比兩臺(tái)服務(wù)器上文件的md5值,達(dá)到檢測(cè)一致性的目的
dir=/data/web
b_ip=192.168.88.10
#將指定目錄下的文件全部遍歷出來(lái)并作為md5sum命令的參數(shù),進(jìn)而得到所有文件的md5值,并寫(xiě)入到指定文件中
find $dir -type f|xargs md5sum > /tmp/md5_a.txt
ssh $b_ip "find $dir -type f|xargs md5sum > /tmp/md5_b.txt"
scp $b_ip:/tmp/md5_b.txt /tmp
#將文件名作為遍歷對(duì)象進(jìn)行一一比對(duì)
for f in `awk '{print 2} /tmp/md5_a.txt'`
do
#以a機(jī)器為標(biāo)準(zhǔn),當(dāng)b機(jī)器不存在遍歷對(duì)象中的文件時(shí)直接輸出不存在的結(jié)果
if grep -qw "$f" /tmp/md5_b.txt
then
md5_a=`grep -w "$f" /tmp/md5_a.txt|awk '{print 1}'`
md5_b=`grep -w "$f" /tmp/md5_b.txt|awk '{print 1}'`
#當(dāng)文件存在時(shí),如果md5值不一致則輸出文件改變的結(jié)果
if [ $md5_a != $md5_b ]
then
echo "$f changed."
fi
else
echo "$f deleted."
fi
done
6. 定時(shí)清空文件內(nèi)容,定時(shí)記錄文件大小
#!/bin/bash ################################################################ #每小時(shí)執(zhí)行一次腳本(任務(wù)計(jì)劃),當(dāng)時(shí)間為0點(diǎn)或12點(diǎn)時(shí),將目標(biāo)目錄下的所有文件內(nèi)容清空,但不刪除文件,其他時(shí)間則只統(tǒng)計(jì)各個(gè)文件的大小,一個(gè)文件一行,輸出到以時(shí)間和日期命名的文件中,需要考慮目標(biāo)目錄下二級(jí)、三級(jí)等子目錄的文件 ################################################################ logfile=/tmp/`date +%H-%F`.log n=`date +%H` if [ $n -eq 00 ] || [ $n -eq 12 ] then #通過(guò)for循環(huán),以find命令作為遍歷條件,將目標(biāo)目錄下的所有文件進(jìn)行遍歷并做相應(yīng)操作 for i in `find /data/log/ -type f` do true > $i done else for i in `find /data/log/ -type f` do du -sh $i >> $logfile done fi
7. 查看局域網(wǎng)內(nèi)主機(jī)是否存活
#!/usr/bin/bash
# check host status
for i in {1..254}
do
{
ip=192.168.8.$i
ping -c 2 -W 1 $ip &>/dev/null
if [ $? -eq 0 ];then
echo "$ip is online" | tee -a /tmp/host_online.txt
else
# echo "$ip is offline" | tee -a /tmp/host_offline.txt
echo "$ip is offline" &>/dev/null
fi
}&
done
wait
8. 自動(dòng)應(yīng)答分發(fā)免密登錄
#!/usr/bin/bash
# ssh keygen
>ip_ok.txt
>ip_false.txt
user=root
passwd=123456
rpm -qa | grep expect &>/dev/null
if [ $? -ne 0 ];then
echo "expect is not install"
yum -y install expect
fi
if [ ! -f ~/.ssh/id_rsa ];then
ssh-keygen -P "" -f ~/.ssh/id_rsa
fi
for i in {15..30}
do
{
ip=192.168.1."$i"
ping -c 1 -W1 "$ip"
if [ $? -eq 0 ];then
echo "$ip" >> ip_ok.txt
/usr/bin/expect <<-EOF
spawn ssh-copy-id $user@$ip
expect {
"yes/no" { send "yes\r"; exp_continue }
"password:" { send "$passwd\r" };
}
expect eof
EOF
else
echo "$ip" >>ip_false.txt
fi
}&
done
wait
echo "finish"
9. 代碼上線腳本
#!/bin/bash
# code online
# author: ren
PROJT_DIR=/usr/local/nginx/html
OLD_DIR=/usr/local/nginx/html/web1
PROJT=web1
BACKUP_DIR=/data/backup
DATA_CHMOD=www
DATE=`date +%F`
NEW_DIR=/data/web1
# 關(guān)閉nginx
function stop_nginx() {
/usr/bin/systemctl stop nginx
if [ $? -eq 0 ];then
echo "nginx is stopd"
else
echo "nginx is not stop please check..."
exit 1
fi
}
#2 備份原有數(shù)據(jù)
function backup_data() {
if [ -d $BACKUP_DIR/$DATE'-'$PROJT ];then
echo "DIR $BACKUP_DIR/$DATE'-'$PROJT is exist"
exit 2
else
mv $OLD_DIR $BACKUP_DIR/$DATE'-'$PROJT
fi
}
# 3移動(dòng)新的代碼 項(xiàng)目目錄 注:此代碼目錄需手動(dòng)上傳解壓
function new_code() {
if [ -d $NEW_DIR ];then
mv $NEW_DIR $PROJT_DIR
else
echo "NEW_DIR is not exist"
exit 3
fi
}
# 4 修改權(quán)限
function chmod_news() {
chown -R $DATA_CHMOD.$DATA_CHMOD $OLD_DIR
}
# 5 啟動(dòng)服務(wù)
function start_nginx() {
/usr/bin/systemctl start nginx
if [ $? -eq 0 ];then
echo "nginx start ok"
else
echo "ngin is not start,please check..."
fi
}
stop_nginx
backup_data
new_code
chmod_news
start_nginx
10. 檢測(cè)MySQL主從復(fù)制是否異常
#!/bin/bash
user="root"
password="123456"
mycmd="mysql -u$user -p$password -h 192.168.1.88"
function chkdb() {
list=($($mycmd -e "show slave status \G"|egrep "Running|Behind"|awk -F: '{print $2}'))
if [ ${list[0]} = "Yes" -a ${list[1]} = "Yes" -a ${list[2]} -lt 120 ]
then echo "Mysql slave is ok"
else echo "Mysql slave replation is filed"
fi
}
function main() {
while true
do chkdb
sleep 3
done
}
main
11. MySQL數(shù)據(jù)庫(kù)備份腳本(mysqldump)
#!/bin/bash
#刪除15天以前備份
source /etc/profile #加載系統(tǒng)環(huán)境變量
source ~/.bash_profile #加載用戶環(huán)境變量
set -o nounset #引用未初始化變量時(shí)退出
#set -o errexit #執(zhí)行shell命令遇到錯(cuò)誤時(shí)退出
user="root"
password="123456"
host="localhost"
port="3306"
#需備份的數(shù)據(jù)庫(kù),數(shù)組
db=("test")
#備份時(shí)加鎖方式,
#MyISAM為鎖表--lock-all-tables,
#InnoDB為鎖行--single-transaction
lock="--single-transaction"
mysql_path="/usr/local/mysql"
backup_path="${mysql_path}/backup"
date=$(date +%Y-%m-%d_%H-%M-%S)
day=15
backup_log="${mysql_path}/backup.log"
#建立備份目錄
if [ ! -e $backup_path ];then
mkdir -p $backup_path
fi
#刪除以前備份
find $backup_path -type f -mtime +$day -exec rm -rf {} \; > /dev/null 2>&1
echo "開(kāi)始備份數(shù)據(jù)庫(kù):${db[*]}"
#備份并壓縮
backup_sql(){
dbname=$1
backup_name="${dbname}_${date}.sql"
#-R備份存儲(chǔ)過(guò)程,函數(shù),觸發(fā)器
mysqldump -h $host -P $port -u $user -p$password $lock --default-character-set=utf8 --flush-logs -R $dbname > $backup_path/$backup_name
if [[ $? == 0 ]];then
cd $backup_path
tar zcpvf $backup_name.tar.gz $backup_name
size=$(du $backup_name.tar.gz -sh | awk '{print $1}')
rm -rf $backup_name
echo "$date 備份 $dbname($size) 成功 "
else
cd $backup_path
rm -rf $backup_name
echo "$date 備份 $dbname 失敗 "
fi
}
#循環(huán)備份
length=${#db[@]}
for (( i = 0; i < $length; i++ )); do
backup_sql ${db[$i]} >> $backup_log 2>&1
done
echo "備份結(jié)束,結(jié)果查看 $backup_log"
du $backup_path/*$date* -sh | awk '{print "文件:" $2 ",大小:" $1}'
到此這篇關(guān)于工作中使用Shell實(shí)用腳本 的文章就介紹到這了,更多相關(guān)Shell實(shí)用腳本內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信