Linux Shell常用技巧(十) 管道組合

Linux Shell常用技巧(十) 管道組合

二十. 通過管道組合Shell命令獲取系統運行數據:


    1.  輸出當前系統中佔用內存最多的5條命令:
    #1) 通過ps命令列出當前主機正在運行的所有進程。
    #2) 按照第五個字段基於數值的形式進行正常排序(由小到大)。
    #3) 僅顯示最後5條輸出。
    /> ps aux | sort -k 5n | tail -5
    stephen   1861  0.2  2.0  96972 21596  ?  S     Nov11   2:24 nautilus
    stephen   1892  0.0  0.4 102108  4508  ?  S<sl Nov11   0:00 /usr/bin/pulseaudio
    stephen   1874  0.0  0.9 107648 10124 ?  S     Nov11   0:00 gnome-volume
    stephen   1855  0.0  1.2 123776 13112 ?  Sl     Nov11   0:00 metacity
    stephen   1831  0.0  0.9 125432  9768  ?  Ssl   Nov11   0:05 /usr/libexec/gnome
    
    2.  找出cpu利用率高的20個進程:
    #1) 通過ps命令輸出所有進程的數據,-o選項後面的字段列表列出了結果中需要包含的數據列。
    #2) 將ps輸出的Title行去掉,grep -v PID表示不包含PID的行。
    #3) 基於第一個域字段排序,即pcpu。n表示以數值的形式排序。
    #4) 輸出按cpu使用率排序後的最後20行,即佔用率最高的20行。
    /> ps -e -o pcpu,pid,user,sgi_p,cmd | grep -v PID | sort -k 1n | tail -20

    3.  獲取當前系統物理內存的總大小:
    #1) 以兆(MB)爲單位輸出系統當前的內存使用狀況。
    #2) 通過grep定位到Mem行,該行是以操作系統爲視角統計數據的。
    #3) 通過awk打印出該行的第二列,即total列。
    /> free -m | grep "Mem" | awk '{print $2, "MB"}'
    1007 MB

二十一. 通過管道組合Shell命令進行系統管理:

    1.  獲取當前或指定目錄下子目錄所佔用的磁盤空間,並將結果按照從大到小的順序輸出:
    #1) 輸出/usr的子目錄所佔用的磁盤空間。
    #2) 以數值的方式倒排後輸出。
    /> du -s /usr/* | sort -nr
    1443980 /usr/share
    793260   /usr/lib
    217584   /usr/bin
    128624   /usr/include
    60748    /usr/libexec
    45148    /usr/src
    21096    /usr/sbin
    6896      /usr/local
    4           /usr/games
    4           /usr/etc
    0           /usr/tmp
    
    2.  批量修改文件名:
    #1) find命令找到文件名擴展名爲.output的文件。
    #2) sed命令中的-e選項表示流編輯動作有多次,第一次是將找到的文件名中相對路徑前綴部分去掉,如./aa改爲aa。
    #    流編輯的第二部分,是將20110311替換爲mv & 20110310,其中&表示s命令的被替換部分,這裏即源文件名。
    #    \1表示被替換部分中#的\(.*\)。
    #3) 此時的輸出應爲
    #    mv 20110311.output 20110310.output
    #    mv 20110311abc.output 20110310abc.output
    #    最後將上面的輸出作爲命令交給bash命令去執行,從而將所有20110311*.output改爲20110311*.output
    /> find ./ -name "*.output" -print  | sed -e 's/.\///g' -e 's/20110311\(.*\)/mv & 20110310\1/g' | bash
   
    3.  統計當前目錄下文件和目錄的數量:
    #1) ls -l命令列出文件和目錄的詳細信息。
    #2) ls -l輸出的詳細列表中的第一個域字段是文件或目錄的權限屬性部分,如果權限屬性部分的第一個字符爲d,
    #    該文件爲目錄,如果是-,該文件爲普通文件。
    #3) 通過wc計算grep過濾後的行數。

    /> ls -l * | grep "^-" | wc -l
    /> ls -l * | grep "^d" | wc -l
   
    4.  殺掉指定終端的所有進程:
    #1) 通過ps命令輸出終端爲pts/1的所有進程。
    #2) 將ps的輸出傳給grep,grep將過濾掉ps輸出的Title部分,-v PID表示不包含PID的行。
    #3) awk打印輸出grep查找結果的第一個字段,即pid字段。
    #4) 上面的三個組合命令是在反引號內被執行的,並將執行的結果賦值給數組變量${K}。
    #5) kill方法將殺掉數組${K}包含的pid。
    /> kill -9 ${K}=`ps -t pts/1 | grep -v PID | awk '{print $1}'`    

    5.  將查找到的文件打包並copy到指定目錄:
    #1) 通過find找到當前目錄下(包含所有子目錄)的所有*.txt文件。
    #2) tar命令將find找到的結果壓縮成test.tar壓縮包文件。
    #3) 如果&&左側括號內的命令正常完成,則可以執行&&右側的shell命令了。
    #4) 將生成後的test.tar文件copy到/home/.目錄下。
    /> (find . -name "*.txt" | xargs tar -cvf test.tar) && cp -f test.tar /home/.
   
    #1) cpio從find的結果中讀取文件名,將其打包壓縮後發送到./dest/dir(目標目錄)。
    #2) cpio的選項介紹:
    #    -d:創建需要的目錄。
    #    -a:重置源文件的訪問時間。
    #    -m:保護新文件的修改時間。
    #    -p:將cpio設置爲copy pass-through模式。
    /> find . -name "*" | cpio -dampv ./dest/dir


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章