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

須要說明的是,該篇Blog中絕大多數的示例來自於互聯網,是本人通過一天左右的時間收集和整理以後篩選出來的,其中註釋部分是我在後來添加的,以便於咱們閱讀時的理解。若是從此再發現更好更巧妙的Shell組合命令,本人將持續更新該Blog。若是您有確實很是不錯的Shell命令組合,且願意和咱們在這裏分享,能夠直接放在回覆中,本人將對該篇Blog始終保持重點關注。更多linux架構乾貨資料領取地址:812855908linux

經過管道組合Shell命令獲取系統運行數據:shell

1. 輸出當前系統中佔用內存最多的5條命令:數組

#1) 經過ps命令列出當前主機正在運行的全部進程。bash

#2) 按照第五個字段基於數值的形式進行正常排序(由小到大)。架構

#3) 僅顯示最後5條輸出。操作系統

/> ps aux | sort -k 5n | tail -5

stephen 1861 0.2 2.0 96972 21596 ? S Nov11 2:24 nautiluscdn

stephen 1892 0.0 0.4 102108 4508 ? S<sl Nov11 0:00 /usr/bin/pulseaudio blog

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
相關文章
相關標籤/搜索