您好,登錄后才能下訂單哦!
shell腳本多線程實現
在使用shell 腳本時,碰到了順序執行太慢的情況,因此考慮使用多線程方式,以提高效率。
具體做法是使用 &+wait 達到多線程的效果,下面請看對比。
順序執行
執行3次沒次等待4秒,共計耗時12秒
代碼:
#/bin/bash
date
for num in seq 1 3
do
{
echo "sleep 4"
sleep 4
}
done
date
結果:
2019年 11月 20日 星期三 09:40:56 CST
sleep 4
sleep 4
sleep 4
2019年 11月 20日 星期三 09:41:08 CST
seq 1 3
根據觀察可以發現&+wait形式會讓循環體內的命令全部進入后臺運行,這樣當處理大量事務時會有問題,所以可以根據以下幾種方式實現控制每次開啟的線程數量
多層for 循環
共計9次,發3個線程,等待4秒,共計耗時12秒
代碼:
#/bin/bash
date
for num2 in seq 1 3
do
{
for num in seq 1 3
do
{
echo "sleep 4"
sleep 4
}&
done
wait
}
done
date
結果:
2019年 11月 20日 星期三 09:47:23 CST
sleep 4
sleep 4
sleep 4
sleep 4
sleep 4
sleep 4
sleep 4
sleep 4
sleep 4
2019年 11月 20日 星期三 09:47:35 CST
all_num=9
thread_num=3
date
seq 1 ${all_num} | xargs -n 1 -I {} -P ${thread_num} sh -c "sleep 4;echo {}"
date
結果:
2019年 11月 20日 星期三 09:51:03 CST
1
3
2
4
5
6
8
9
7
2019年 11月 20日 星期三 09:51:15 CST
以上就是我總結的shell 并行方式。還有使用GNU parallel命令實現并發的方式,因為測試環境沒有改命令,故沒做測試,待測試環境有之后會補全。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。