二十. 通過管道組合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
最後需要說明的是,該篇Blog中絕大多數的示例來自於互聯網,是本人經過一天左右的時間收集和整理之後篩選出來的,其中註釋部分是我在後來添加的,以便於我們閱讀時的理解。如果今後再發現更好更巧妙的Shell組合命令,本人將持續更新該Blog。如果您有確實非常不錯的Shell命令組合,且願意和我們在這裏分享,可以直接放在回覆中,本人將對該篇Blog始終保持重點關注。
二十二. 交互式使用Bash Shell:
1. 用set命令設置bash的選項:
下面爲set主要選項的列表及其表述:
選項名 |
開關縮寫 |
描述 |
allexport |
-a |
打開此開關,所有變量都自動輸出給子Shell。 |
noclobber |
-C |
防止重定向時文件被覆蓋。 |
noglob |
-d |
在路徑和文件名中,關閉通配符。 |
#打開該選項
/> set -o allexport #等同於set -a
#關閉該選項
/> set +o allexport #等同於set +a
#列出當前所有選項的當前值。
/> set -o
allexport off
braceexpand on
emacs on
errexit off
errtrace off
functrace off
hashall on
histexpand on
... ...
/> set -o noclobber #打開noclobber選項,防止在重定向時原有文件被覆蓋。
/> date > outfile #通過date命令先生成一個文件outfile。
/> ls > outfile #將ls命令的輸出重定向到該文件outfile,shell將提示不能覆蓋已經存在的文件。
-bash: outfile: cannot overwrite existing file
/> set +o noclobber #關閉noclobber選項。
/> ls > outfile #重新將ls的輸出重定向到outfile,成功。
2. 變量:
設置局部變量:
/> name="stephen liu" #注意等號兩邊不要有空格,如果變量值之間存在空格,則需要用雙引號括起
/> echo $name
stephen liu
/> name= #將變量設置爲空時,等號後面也不要有空格,直接回車即可。
/> echo $name #name變量爲空,因此echo不會有任何輸出。
注意:以上變量的聲明方式均可替換爲declare variable=value的形式。
/> declare name="stephen liu"
/> readonly name #將name變量設置爲只讀。
/> echo $name
stephen liu
/> name="my wife" #如果針對只讀變量重新賦值,將報錯,提示name是隻讀變量。
-bash: name: readonly variable
/> unset name #如果unset只讀變量,將同樣報錯,提示不能unset只讀變量。
-bash: unset: name: cannot unset: readonly variable
設置全局/環境變量:
在當前Shell中創建的全局/環境變量可以直接傳遞給它所有的子Shell,當前創建環境變量的Shell被稱爲夫Shell。
/> export allname=john #利用export命令,將其後聲明的變量置爲環境變量
/> bash #啓動一個新的子Shell
/> echo $allname #在子Shell中echo變量$allname,發現夫Shell中設置的值被傳遞到子Shell
john
/> declare -x allname2=peter #這裏的功能和結果都是和上面的命令相同,只是利用declare -x命令設置環境變量
/> bash
/> echo $allname2
peter
下面的列表將給出常用的內置Shell環境變量:
變量名 |
含義 |
BASH |
表示bash命令的完整路徑名。 |
ENV |
在啓動新bash shell時執行的環境文件名。 |
HOME |
主目錄。 |
LANG |
本地化語言。 |
PATH |
命令搜索路徑,彼此之間冒號分隔。 |
PPID |
父進程PID。 |
PWD |
當前工作目錄,用cd命令設置。 |