共計 2944 個字符,預(yù)計需要花費 8 分鐘才能閱讀完成。
這篇文章將為大家詳細講解有關(guān) linux 中實用的 Shell 示例有哪些,丸趣 TV 小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
1、并發(fā)從數(shù)臺機器中獲取 hostname,并記錄返回信息花費的時長,重定向到一個文件 hostname.txt 中,在全部完成后輸出花費時長最短的那臺機器的 CPU 信息。
#!bin/bash # 所以主機,以空格分隔 ALL_HOSTS=(IP 地址 IP 地址) for host in ${ALL_HOSTS[*]} do { start_time=$(date + %s) ssh $host hostname /dev/null sleep 2 stop_time=$(date + %s) time_consuming=$((stop_time-start_time)) echo $host: $time_consuming hostname.txt } done wait host=$(sort -n -k 2 hostname.txt | head -1 | awk -F : {print $1} ) ssh $host top -b -n 1
2、統(tǒng)計 /proc 目類下 Linux 進程相關(guān)數(shù)量信息,輸出總進程數(shù),running 進程數(shù),stoped 進程數(shù),sleeing 進程數(shù),zombie 進程數(shù)。
輸出所有 zombie 的進程到 zombie.txt 殺死所有 zombie 進程。
#!/bin/bash ALL_PROCESS=$(ls /proc/ | egrep [0-9]+ ) running_count=0 stoped_count=0 sleeping_count=0 zombie_count=0 for pid in ${ALL_PROCESS[*]} do test -f /proc/$pid/status state=$(egrep State /proc/$pid/status | awk {print $2} ) case $state in R) running_count=$((running_count+1)) ;; T) stoped_count=$((stoped_count+1)) ;; S) sleeping_count=$((sleeping_count+1)) ;; Z) zombie_count=$((zombie_count+1)) echo $pid zombie.txt kill -9 $pid ;; esac done echo -e total: $((running_count+stoped_count+sleeping_count+zombie_count))\nrunning: $running_count\nstoped: $stoped_count\nsleeping: $sleeping_count\nzombie: $zombie_count
3、把當(dāng)前目錄(包含子目錄)下所有后綴為 .sh 的文件后綴變更為 .shell,之后刪除每個文件的第二行。
#!/bin/bash ALL_SH_FILE=$(find . -type f -name *.sh) for file in ${ALL_SH_FILE[*]} do filename=$(echo $file | awk -F .sh {print $1} ) new_filename= ${filename}.shell mv $file $new_filename sed -i 2d $new_filename done
4、判斷目錄 /tmp/jstack 是否存在,不存在則新建一個目錄,若存在則刪除目錄下所有內(nèi)容。
每隔 1 小時打印 inceptor server 的 jstack 信息,并以 jstack_${當(dāng)前時間} 命名文件,每當(dāng)目錄下超過 10 個文件后,刪除最舊的文件。
#!/bin/bash DIRPATH= /tmp/jstack CURRENT_TIME=$(date + %F - %H:%M:%S) if [ ! -d $DIRPATH ];then mkdir $DIRPATH else rm -rf $DIRPATH /* fi cd $DIRPATH while true do sleep 3600 # 這里需要將 inceptor 改后自己的 java 進程名稱 pid=$(ps -ef | grep inceptor | grep -v grep | awk {print $2} ) jstack $pid jstack_${CURRENT_TIME} dir_count=$(ls | wc -l) if [ $dir_count -gt 10 ];then rm -f $(ls -tr | head -1) fi done
5、從 test.log 中截取當(dāng)天的所有 gc 信息日志,并統(tǒng)計 gc 時間的平均值和時長最長的時間。
#!/bin/bash awk {print $2} hive-server2.log | tr -d : | awk {sum+=$1} END {print avg: , sum/NR} capture_hive_log.log awk {print $2} hive-server2.log | tr -d : | awk {max = 0} {if ($1+0 max+0) max=$1} END {print Max: , max} capture_hive_log.log
6、查找 80 端口請求數(shù)最高的前 20 個 IP 地址,判斷中間最小的請求數(shù)是否大于 500,如大于 500,則輸出系統(tǒng)活動情況報告到 alert.txt,如果沒有,則在 600s 后重試,直到有輸出為止。
#!/bin/bash state= true while $state do SMALL_REQUESTS=$(netstat -ant | awk -F [ :]+ /:22/{count[$4]++} END {for(ip in count) print count[ip]} | sort -n | head -20 | head -1) if [ $SMALL_REQUESTS -gt 500 ];then sar -A alert.txt state= false else sleep 6 continue fi done
7、將當(dāng)前目錄下大于 10K 的文件轉(zhuǎn)移到 /tmp 目錄,再按照文件大小順序,從大到小輸出文件名。
#!/bin/bash # 目標目錄 DIRPATH= /tmp # 查看目錄 FILEPATH= . find $FILEPATH -size +10k -type f | xargs -i mv {} $DIRPATH ls -lS $DIRPATH | awk {if(NR 1) print $NF}
關(guān)于“l(fā)inux 中實用的 Shell 示例有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。