這篇文章將為大家詳細(xì)講解有關(guān)linux中實(shí)用的Shell示例有哪些,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)提供從項(xiàng)目策劃、軟件開發(fā),軟件安全維護(hù)、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評估等整套的建站服務(wù),主營業(yè)務(wù)為網(wǎng)站設(shè)計(jì)制作、網(wǎng)站制作,成都APP應(yīng)用開發(fā)以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。創(chuàng)新互聯(lián)公司深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
1、并發(fā)從數(shù)臺機(jī)器中獲取 hostname,并記錄返回信息花費(fèi)的時(shí)長,重定向到一個(gè)文件 hostname.txt 中,在全部完成后輸出花費(fèi)時(shí)長最短的那臺機(jī)器的 CPU 信息。
#!bin/bash # 所以主機(jī),以空格分隔 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)計(jì) /proc 目類下 Linux 進(jìn)程相關(guān)數(shù)量信息,輸出總進(jìn)程數(shù),running 進(jìn)程數(shù),stoped 進(jìn)程數(shù),sleeing 進(jìn)程數(shù),zombie 進(jìn)程數(shù)。
輸出所有 zombie 的進(jìn)程到 zombie.txt 殺死所有 zombie 進(jìn)程。
#!/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",之后刪除每個(gè)文件的第二行。
#!/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 是否存在,不存在則新建一個(gè)目錄,若存在則刪除目錄下所有內(nèi)容。
每隔 1 小時(shí)打印 inceptor server 的 jstack 信息,并以 jstack_${當(dāng)前時(shí)間} 命名文件,每當(dāng)目錄下超過 10 個(gè)文件后,刪除最舊的文件。
#!/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進(jìn)程名稱 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)計(jì) gc 時(shí)間的平均值和時(shí)長最長的時(shí)間。
#!/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 個(gè) IP 地址,判斷中間最小的請求數(shù)是否大于 500,如大于 500,則輸出系統(tǒng)活動情況報(bào)告到 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 # 目標(biāo)目錄 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中實(shí)用的Shell示例有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。