今天讀程序找田,遇到一些sed命令和awk命令不太明白怨酝,于是去認(rèn)真查了查您炉,搞清楚并且總結(jié)于此驻粟。
mnt=$(readlink -f $(grep -P "_dbdir_.*_nodeid_" some.conf | sed "s#.*_dbdir_\(.*\)_nodeid_#$dbdir\1$nd#")|sed 's#/HAS[0-9]*/\([a-zA-Z0-9_-]*\)#\1#')
好長饭宾,打字都好累批糟,這么多符號(hào),當(dāng)初誰寫的啊= =
又遇到一個(gè)比較難的sed命令行捏雌,簡(jiǎn)直醉了跃赚。
sed -n '/^\['$nd_str'\]/,/^\[/{s/ *'DBDir'[ ]*= *\(.*\)[ ]*$/\1/p;}' kernelite.ini
- readlink命令
readlink是用來找出符號(hào)鏈接指向的位置,使用readlink --help
to print value of symbolic link or canonical name
-f 參數(shù)是 遞歸跟隨給出文件名的所有符號(hào)鏈接以標(biāo)準(zhǔn)化 - grep -P -o -c命令
-P, --perl-regexp: Interpret PATTERN as a Perl regular expression.
-o, --only-matching: Show only the part of a matching line that matches PATTERN.
-c,只輸出匹配行的計(jì)數(shù)
-s ,不顯示不存在或無匹配文本的錯(cuò)誤信息纬傲。
-q: 靜默模式, 不輸出任何結(jié)果
-w: does a word search 全字匹配 - ps命令
顯示當(dāng)前進(jìn)程的狀態(tài)
-e
同-A
,顯示所有進(jìn)程
-o
表示自定義顯示
-C<命令>
列出指定命令的狀況
pid=$(ps -e -o pid,args | awk '/'$SysGov'$/{print $1}')
- xargs
將前一個(gè)命令的輸出作為參數(shù)
ps -e -o pid,args | egrep "$SysGov$|$SysGov .*ini$" |cut -c1-5 | xargs kill -9 2>/dev/null
另外一個(gè)例子
file -Lz *|grep ASCII |cut -d":" -f1 | xargs ls -ltr
- killall命令
killall命令用于殺死指定名字的進(jìn)程满败,kill是殺死指定PID的進(jìn)程,但是在這之前要使用ps等命令再grep來查找進(jìn)程
ssh $i "killall -9 $UBSH 2>/dev/null
- scp命令
-p
保留原文件的修改時(shí)間以及權(quán)限
-q
不顯示傳輸進(jìn)度條
scp -qp $srcdir/SysGovernor $SysGov
- ln命令
-f
強(qiáng)制執(zhí)行
-s
軟連接叹括,符號(hào)鏈接
第一個(gè)是源文件算墨,第二個(gè)是目標(biāo)文件,硬鏈接是一個(gè)檔案可以有多個(gè)名稱汁雷,軟鏈接是一個(gè)特殊的檔案指向另外一個(gè)檔案的位置净嘀。
ln -fs $UBClient UBClient
- sed命令
sed是在線編輯器,一次處理一行內(nèi)容侠讯,處理的時(shí)候把當(dāng)前的行存儲(chǔ)在臨時(shí)緩沖區(qū)中挖藏,sed命令處理緩沖區(qū)中的內(nèi)容,處理完成后厢漩,把緩沖區(qū)的內(nèi)容送往屏幕膜眠。
sed 1d
刪除第一行
\(..\)
:保存括號(hào)內(nèi)匹配的字符,在上面的匹配中溜嗜,括號(hào)中一般匹配到的是/
sed 's/test/mytest/g example
將整行范圍內(nèi)進(jìn)行替換宵膨,沒有g(shù)標(biāo)記,每行直郵第一個(gè)匹配的test被替換
sed 's/\(love\)able/\1rs/p' example
love被標(biāo)記為 1炸宵,然后進(jìn)行替換成lovers
sed 's#19#100#g' example
不論什么字符辟躏,緊跟著s命令的都被認(rèn)為是新的分隔符,#代替了/作為分隔符
*
表示匹配0個(gè)或者多個(gè)字符
.
表示匹配一個(gè)非換行符的字符
sed -n
取消默認(rèn)輸出土全,等同于--quiet
,--silent
sed -n '/test/,/check/p' example
所有在test和check所確定的范圍內(nèi)的行都將被打印捎琐,主要是有p選項(xiàng)
sed '/test/,/check/s/$/sed test/' example
對(duì)于模版test和check之間的行,每行的末尾都用sed test進(jìn)行替換涯曲。上面的程序就是如此野哭,只不過后面的替換s命令太長,所以就使用了{(lán)}幻件,然后里面命令后面要加分號(hào),也就是對(duì)于每一個(gè)node的信息段蛔溃,將DBDir的路徑打印出來绰沥,注意-n選項(xiàng)的使用,以及p選項(xiàng)的使用贺待。 - awk命令
awk同樣也是行處理器徽曲,在與屏幕處理相比較,處理龐大文件的時(shí)候不會(huì)出現(xiàn)內(nèi)存溢出或者處理緩慢麸塞,用來格式化文本信息秃臣。
has=$(grep -P "^$mnt\t" $autohas | awk -F '\t|:' '{print $2}' | sort -u)
awk [-F|-f|-v] 'BEGIN{} //{command1;command2} END{}' file
是awk命令形式
awk -F '\t|:'
用于指定分隔符是\t或者:
-f
參數(shù)是調(diào)用腳本
-v
定義變量 var=value
$0
表示整個(gè)當(dāng)前行
$1
表示每行的第一個(gè)字段
NF
字段數(shù)量變量
NR
每行的紀(jì)錄號(hào),多個(gè)文件遞增
FNR
每行的記錄號(hào)
FS
BEGIN定義分隔符
RS
輸入的紀(jì)錄分隔符,默認(rèn)是一行一行輸入奥此,換行符
OFS
輸出字段分隔符弧哎,默認(rèn)是空格
ORS
輸出的紀(jì)錄分隔符,默認(rèn)是換行符
-F '[:#/]'
定義三個(gè)分隔符
awk -f script.awk file 'BEGIN{FS=":"} {print $1}'
- 一些例子
1)sed與awk
sed 's/#.*//; s/[:=]/ /g' param.ini|awk '/NodeIP/ {print ++c-1,$2}'|grep -w x139|cut -d' ' -f1
首先sed執(zhí)行了替換操作稚虎,第一個(gè)替換是把#以及后面的內(nèi)容替換為空撤嫩,然后是將: =這兩個(gè)符號(hào)替換為空白字符串,接下來尋找有NodeIP的一行蠢终,打印c以及第二個(gè)字段序攘,c默認(rèn)初始值為0,也就是nodes的序號(hào)寻拂,然后執(zhí)行精確匹配grep -w匹配出需要的nodes的行程奠,然后獲取其序號(hào)。
2). pgrep以及awk
ki=$(pgrep -lf $SysGov | awk '/-k/{print $NF}')
pgrep查看進(jìn)程的消息祭钉,通過進(jìn)程名字來查詢進(jìn)程梦染,判斷程序是否在運(yùn)行
-l
表示同時(shí)顯示進(jìn)程名和PID
-f
表示全部命令行,包括命令執(zhí)行參數(shù)
/-k/{print $NF}
表示匹配-k朴皆,然后NDF表示字段數(shù)量帕识,也就是說打印出最后一個(gè)字段
3).一個(gè)循環(huán)處理
i=0
while((i<3));do
echo $(uptime|cut -d, -f3-|cut -d: -f2)
i=$[ $i + 1 ]
done|awk '{x += $1} END{printf "%.0f\n",x}'```
打印出3次uptime之和,因?yàn)镋ND是當(dāng)程序運(yùn)行結(jié)束后才會(huì)運(yùn)行的遂铡。