1. 程式人生 > >周天奮戰一天Linux Shell常用技巧(十)

周天奮戰一天Linux Shell常用技巧(十)

 

 

 

 

  需要說明的是,該篇Blog中絕大多數的示例來自於網際網路,是本人經過一天左右的時間收集和整理之後篩選出來的,其中註釋部分是我在後來新增的,以便於我們閱讀時的理解。如果今後再發現更好更巧妙的Shell組合命令,本人將持續更新該Blog。如果您有確實非常不錯的Shell命令組合,且願意和我們在這裡分享,可以直接放在回覆中,本人將對該篇Blog始終保持重點關注。更多linux架構乾貨資料領取地址:812855908

通過管道組合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/di