国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 系統(tǒng) > Linux > 正文

Shell中實(shí)現(xiàn)“多線程”執(zhí)行腳本文件完美解決方案

2019-10-26 18:44:05
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

即比如我有100個(gè)可執(zhí)行文件,互相間沒(méi)有特別的先后執(zhí)行關(guān)系,如CODE:
代碼如下:
job_1
job_2
job_2
.....
job_100

想用csh/bash來(lái)多線程調(diào)用執(zhí)行。

比如一次開5個(gè)線程,那么job_1,2,3,4,5一起先開始,那么其中任何一個(gè)線程如果先執(zhí)行完成,則繼續(xù)執(zhí)行下一個(gè)沒(méi)有初執(zhí)行過(guò)的文件,如job_6,7,8....,這樣一直以所指定的線程數(shù)來(lái)執(zhí)行所有100個(gè)文件。

我本來(lái)想用 "&" 來(lái)放入后臺(tái),可是這樣我一次可以指定5放入后臺(tái),但是無(wú)法知道其中任何一個(gè)程序何時(shí)執(zhí)行完畢,所以也無(wú)法繼續(xù)執(zhí)行下一個(gè)程序啊!

完美解決方案:
代碼如下:
-(dearvoid@LinuxEden:Forum)-(~/tmp)-
[$$=6718 $?=0] ; cat job_1
#!/bin/bash
n=$((RANDOM % 5 + 1))
echo "$0 sleeping for $n seconds ..."
sleep $n
echo "$0 exiting ..."
-(dearvoid@LinuxEden:Forum)-(~/tmp)-
[$$=6718 $?=0] ; for ((i = 2; i <= 10; ++i)); do cp job_1 job_$i; done
-(dearvoid@LinuxEden:Forum)-(~/tmp)-
[$$=6718 $?=0] ; cat jobs.sh
#!/bin/bash
nParellel=5
nJobs=10
sJobPattern='./job_%d'
aJobs=()
sNextJob=
for ((iNextJob = 1; iNextJob <= nJobs; )); do
    for ((iJob = 0; iJob < nParellel; ++iJob)); do
        if [ $iNextJob -gt $nJobs ]; then
            break;
        fi
        if [ ! "${aJobs[iJob]}" ] || ! kill -0 ${aJobs[iJob]} 2> /dev/null; then
            printf -v sNextJob "$sJobPattern" $((iNextJob++))
            echo "$sNextJob starting ..."
            $sNextJob &
            aJobs[iJob]=$!
        fi
    done
    sleep .1
done
wait
-(dearvoid@LinuxEden:Forum)-(~/tmp)-
[$$=6718 $?=0] ; ./jobs.sh
./job_1 starting ...
./job_1 sleeping for 3 seconds ...
./job_2 starting ...
./job_2 sleeping for 2 seconds ...
./job_3 starting ...
./job_3 sleeping for 5 seconds ...
./job_4 starting ...
./job_5 starting ...
./job_4 sleeping for 4 seconds ...
./job_5 sleeping for 2 seconds ...
./job_2 exiting ...
./job_6 starting ...
./job_6 sleeping for 2 seconds ...
./job_5 exiting ...
./job_7 starting ...
./job_7 sleeping for 1 seconds ...
./job_1 exiting ...
./job_8 starting ...
./job_8 sleeping for 3 seconds ...
./job_7 exiting ...
./job_9 starting ...
./job_9 sleeping for 5 seconds ...

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 喀喇沁旗| 白山市| 泸州市| 广汉市| 南部县| 九龙城区| 达拉特旗| 眉山市| 崇仁县| 莫力| 教育| 海安县| 滨州市| 巴中市| 平山县| 和静县| 广州市| 鄂尔多斯市| 五大连池市| 石嘴山市| 吴堡县| 安丘市| 黑水县| 岐山县| 临颍县| 丹巴县| 霍山县| 太湖县| 泉州市| 祁连县| 和田县| 樟树市| 玉环县| 尼木县| 潍坊市| 汤阴县| 天全县| 武功县| 通城县| 民和| 麻栗坡县|