day 15-16 例題16-25
阿新 • • 發佈:2019-01-09
例題16
[1]+ Stopped vim 16.sh [[email protected] xiti]# fg vim 16.sh #Linux系統中是否有自定義使用者 #!/bin/bash v=`awk -F 'release ' '{print $2}' /etc/redhat-release |cut -d '.' -f1` user() { if [ $1 -eq 0 ] then echo "系統沒有自定義的使用者" else echo "系統存在自定義使用者,有$1個" fi } case $v in 5|6) n=`awk -F ':' '$3>=500' /etc/passwd|wc -l` user $n ;; 7) n=`awk -F ':' '$3>=1000' /etc/passwd|wc -l` user $n ;; *) echo "指令碼出錯." ;; esac
例題17
[[email protected] xiti]# fg vim 17.sh #檢測所有磁碟分割槽使用率和inode使用率並記錄到以當天日期為命名的日誌檔案裡,當發現某個分割槽容量或者inode使用量大於85%時,發郵件通知dir=/tmp/disk #!/bin/bash dir=/tmp/disk d=`date +%F` mail=123@qq.com [ -d $dir ] || mkdir $dir df >> $dir/$d.log df -i >> $dir/$d.log df|sed '1d' |awk -F ' +|%' '$5>=85 {print $7}' > $dir/df.tmp df -i|sed '1d' |awk -F ' +|%' '$5>=85 {print $7}' > $dir/df_i.tmp n1=`wc -l $dir/df.tmp|awk '{print $1}'` n2=`wc -l $dir/df_i.tmp|awk '{print $1}'` tag=0 if [ $n1 -gt 0 ] then if [ $n2 -gt 0 ] then tag=11 else tag=10 fi else if [ $n2 -gt 0 ] then tag=01 else tag=00 fi fi case $tag in 11) python mail.py $mail "磁碟空間和inode使用率高於85%" "`cat $dir/df.tmp $dir/df_i.tmp|xargs`" ;; 10) python mail.py $mail "磁碟空間使用率高於85%" "`cat $dir/df.tmp|xargs`" ;; 01) python mail.py $mail "磁碟inode使用率高於85%" "`cat $dir/df_i.tmp|xargs`" ;; *) ;; esac
例題18
[[email protected] xiti]# vim 18.sh #每5分鐘做一次檢測是否有新檔案生成,若是有新檔案,將新檔案的列表輸出到一個按年、月、日、時、分為名字的日誌裡 #!/bin/bash basedir=/data/web/attachment t=`date +%Y%m%d%H%M` find $basedir/ -type f -mmin -5 > /tmp/file.list n=`wc -l /tmp/file.list|awk '{print $1}'` if [ $n -lt 0 ] then mv /tmp/file.list /tmp/$t.list fi ~
例題19
[[email protected] xiti]# vim 19.sh #寫一個shell指令碼來看看你使用最多的命令是哪些,列出你最常用的命令top10 #!/bin/bash cat ~/.bash_history |sort |uniq -c |sort -nr |head ~
例題20
[[email protected] xiti]# vim 20.sh #當時間是0點和12點時,需要將目錄/data/log/下的檔案全部清空,其他時間只需要統計一下每個檔案的大小,一個檔案一行,輸出到一個按日期和時間為名字的日誌裡 #需要考慮/data/log/目錄下的二級、三級、… 等子目錄裡面的檔案 #!/bin/bash dir=/tmp/log_stat t=`date +%d%H` t1=`date +%H` logdir=/data/log [ -d $dir ] || mkdir $dir [ -f $dir/$t.log ] && rm -f $dir/$t.log if [ $t == "00" -o $t == "12" ] then for f in `find $logdir/ -type f` do > $f done else for f in `find $logdir/ -type f` do du -sh $f >> $dir/$t.log done fi ~
例題21
#每一行中出現的數字個數並且要計算一下整個文件中一共出現了幾個數字 [[email protected] xiti]# cat 21.sh #!/bin/bash sum=0 while read line do line_n=`echo $line|sed 's/[^0-9]//g'|wc -L` echo $line_n sum=$[$sum+$line_n] done < $1 echo "sum:$sum" [[email protected] xiti]#
例題22
[[email protected] xiti]# vim 22.sh #檢測A機器和B機器/data/web/目錄下檔案的異同,我們以A機器上的檔案作為標準。 比如,假若B機器少了一個a.txt檔案,那我們應該能夠檢測出來,或者B機器上的b.txt檔案有過改動,我們也應該能夠檢測出來(B機器上多了檔案不用考慮)。 #!/bin/bash dir=/data/web [ -f /tmp/md5.list ] && rm -f /tmp/md5.list find $dir/ -type f > /tmp/file.list while read line do md5sum $line >> /tmp/md5.list done < /tmp/file.list scp /tmp/md5.list B:/tmp/ [ -f /tmp/check_md5.sh ] && rm -f /tmp/check_md5.sh cat >/tmp/check_md5.sh << EOF #!/bin/bash dir=/data/web n=\`wc -l /tmp/md5.list|awk '{print \$1}'\` for i in \`seq 1 \$n\` do file_name=\`sed -n "\$i"p /tmp/md5.list |awk '{print \$1}'\` md5=\`sed -n "\$i"p /tmp/md5.list|awk '{print \$2}'\` if [ -f \$file_name ] then md5_b=\`md5sum \$file_name\` if [\$md5_b != \$md5 ] then echo "\$file_name changed." fi else echo "\$file_name lose." fi done EOF scp /tmp/check_md5.sh B:/tmp/ ssh B "/bin/bash /tmp/check_md5.sh"
例題23
[[email protected] xiti]# vim 23.sh #檢測你的網路流量,並記錄到一個日誌裡。 並且一分鐘統計一次 #!/bin/bash logdir=/tmp/sar_log file=$logdir/`date +%d%H`.log t=`date +"%F %H:%M"` [ -d $logdir ] || mkdir -p $logdir LANG=en sar -n DEV 1 5 |grep eth0 |grep "Average" > /tmp/sar.tmp exec >>$file echo "$t" awk '{print "eth0 input:",$5*8000"bps""\n""eth0 output:",$6*8000"bps"}' /tmp/sar.tmp echo "#### ###################"
例題24
[[email protected] xiti]# vim 24.sh #寫一個指令碼批量殺死所有sh的程序 #!/bin/bash for pid in `ps aux |grep clearnen.sh |awk '{print $2}'` do echo $pid kill -9 $pid done ~
例題25
[[email protected] xiti]# vim 25.sh #判斷你的Linux伺服器裡是否開啟web服務 如果開啟了,請判斷出跑的是什麼服務 #!/bin/bash n=`netstat -lntp |grep ':80 '|wc -l` if [ $n -eq 0 ] then echo " it is not listen port 80" else ser=`netstat -lntp |grep ':80 '|awk -F '/' '{print $NF}'|sed 's/ //g'` echo "It is listenning port 80, and the service is $ser." fi ~