Shell腳本并發(fā)及并發(fā)數(shù)的控制


正常情況下桥温,Shell腳本是串行執(zhí)行的跛璧,一條命令執(zhí)行完才會執(zhí)行接下來的命令。如下代碼:

# !/bin/bash

for i in `seq 1 10` 
do
    echo $i
done

echo "----end----"

腳本執(zhí)行的結(jié)果如下:

1
2
3
4
5
6
7
8
9
10
----end----

echo $1 命令串行執(zhí)行迈倍,如果命令耗時較長導致總時間較長。如果命令之間沒有互相依賴關(guān)系時捣域,可以讓命令并行執(zhí)行啼染,并行執(zhí)行的方法就是在命令后加上 & 符號。

# !/bin/bash

for i in `seq 1 10` 
do
    echo $i &
done

echo "----end----"

腳本執(zhí)行的結(jié)果如下:

1
2
3
5
4
----end----
10
7
8
9
6

可以看到焕梅,這樣不能保證命令的執(zhí)行順序迹鹅,有的時候需要保證for循環(huán)所有命令執(zhí)行完后再向后執(zhí)行接下來的命令≌暄裕可以使用 wait 實現(xiàn)

# !/bin/bash

for i in `seq 1 10` 
do
    echo $i &
done

wait
echo "----end----"

腳本執(zhí)行的結(jié)果如下:

1
2
3
6
9
10
4
5
7
8
----end----

問題還沒有結(jié)束斜棚,當需要并行執(zhí)行的命令數(shù)量特別多的時候,特別是執(zhí)行命令的資源占用較多時该窗,直接用 & 實現(xiàn)并行容易將服務器資源占用打滿弟蚀,影響其他程序運行。
使用管道和令牌原理實現(xiàn)并發(fā)控制挪捕。

#!/bin/bash
# Step1 創(chuàng)建有名管道
[ -e ./fd1 ] || mkfifo ./fd1

# 創(chuàng)建文件描述符粗梭,以可讀(<)可寫(>)的方式關(guān)聯(lián)管道文件争便,這時候文件描述符3就有了有名管道文件的所有特性
exec 3<> ./fd1   

# 關(guān)聯(lián)后的文件描述符擁有管道文件的所有特性,所以這時候管道文件可以刪除级零,我們留下文件描述符來用就可以了
rm -rf ./fd1                    

# Step2 創(chuàng)建令牌 
for i in `seq 1 2`;
do
    # echo 每次輸出一個換行符,也就是一個令牌
    echo >&3                   
done

# Step3 拿出令牌,進行并發(fā)操作
for line in `seq 1 10`;
do
    read -u3                    # read 命令每次讀取一行滞乙,也就是拿到一個令牌   
    {
        echo $line 
        echo >&3                # 執(zhí)行完一條命令會將令牌放回管道
    }&
done

wait

exec 3<&-                       # 關(guān)閉文件描述符的讀
exec 3>&-                       # 關(guān)閉文件描述符的寫
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末奏纪,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子斩启,更是在濱河造成了極大的恐慌序调,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件兔簇,死亡現(xiàn)場離奇詭異发绢,居然都是意外死亡,警方通過查閱死者的電腦和手機垄琐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進店門边酒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人狸窘,你說我怎么就攤上這事墩朦。” “怎么了翻擒?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵氓涣,是天一觀的道長牛哺。 經(jīng)常有香客問我,道長劳吠,這世上最難降的妖魔是什么引润? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮痒玩,結(jié)果婚禮上椰拒,老公的妹妹穿的比我還像新娘。我一直安慰自己凰荚,他們只是感情好燃观,可當我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著便瑟,像睡著了一般缆毁。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上到涂,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天脊框,我揣著相機與錄音,去河邊找鬼践啄。 笑死浇雹,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的屿讽。 我是一名探鬼主播昭灵,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼伐谈!你這毒婦竟也來了烂完?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤诵棵,失蹤者是張志新(化名)和其女友劉穎抠蚣,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體履澳,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡嘶窄,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了距贷。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片柄冲。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖储耐,靈堂內(nèi)的尸體忽然破棺而出羊初,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布长赞,位于F島的核電站晦攒,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏得哆。R本人自食惡果不足惜脯颜,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望贩据。 院中可真熱鬧栋操,春花似錦、人聲如沸饱亮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽近上。三九已至剔宪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間壹无,已是汗流浹背葱绒。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留斗锭,地道東北人地淀。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像岖是,于是被迫代替她去往敵國和親帮毁。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內(nèi)容