Linux BASH多進(jìn)程并行處理的方法實(shí)現(xiàn)
更新時(shí)間:2013年01月23日 14:56:44 作者:
Linux下BASH多進(jìn)程并行處理的實(shí)現(xiàn)代碼,需要的朋友可以參考下
復(fù)制代碼 代碼如下:
#!/bin/bash
SEND_THREAD_NUM=13
tmp_fifofile="/tmp/$$.fifo" # 腳本運(yùn)行的當(dāng)前進(jìn)程ID號作為文件名
mkfifo “$tmp_fifofile" # 新建一個(gè)隨機(jī)fifo管道文件
exec 6<>"$tmp_fifofile" # 定義文件描述符6指向這個(gè)fifo管道文件
rm $tmp_fifofile
for ((i=0;i<$SEND_THREAD_NUM;i++));do
echo # for循環(huán) 往 fifo管道文件中寫入13個(gè)空行
done >&6
for i in `seq 100`;do # 100 次 for 循環(huán) 開始
read -u6 # 從文件描述符6中讀取行(實(shí)際指向fifo管道)
{
echo $i # 打印 i
sleep 3 # 暫停3秒
echo >&6 # 再次往fifo管道文件中寫入一個(gè)空行。
} &
# {} 這部分語句被放入后臺作為一個(gè)子進(jìn)程執(zhí)行,所以不必每次等待3秒后執(zhí)行
#下一個(gè),這部分的echo $i幾乎是同時(shí)完成的,當(dāng)fifo中13個(gè)空行讀完后 for循環(huán)
# 繼續(xù)等待 read 中讀取fifo數(shù)據(jù),當(dāng)后臺的13個(gè)子進(jìn)程等待3秒后,按次序
# 排隊(duì)往fifo輸入空行,這樣fifo中又有了數(shù)據(jù),for語句繼續(xù)執(zhí)行
pid=$! #打印最后一個(gè)進(jìn)入后臺的子進(jìn)程id
echo $pid
done
wait
exec 6>&- #刪除文件描述符6
exit 0
相關(guān)文章
shell中嵌套執(zhí)行expect命令實(shí)例
這篇文章主要介紹了shell中嵌套執(zhí)行expect命令實(shí)例,一直都想把expect的操作寫到bash腳本里,這樣就不用我再寫兩個(gè)腳本來執(zhí)行了,需要的朋友可以參考下2014-12-12shell腳本學(xué)習(xí)指南[一](Arnold Robbins & Nelson H.F. Beebe著)
這篇文章主要介紹了shell腳本學(xué)習(xí)指南[一]Arnold Robbins & Nelson H.F. Beebe著,需要的朋友可以參考下2014-02-02Jenkinsfile?中如何在?`sh`?步驟中執(zhí)行多行?Shell?命令(多行命令的方法)
在?Jenkinsfile?中,當(dāng)你需要在?sh?步驟中執(zhí)行多行?Shell?命令時(shí),可以通過多種方式來實(shí)現(xiàn),下面給大家分享實(shí)現(xiàn)多行命令的方法,感興趣的朋友一起看看吧2024-02-02