Shell 에서 "다 중 스 레 드"실행 스 크 립 트 파일 완벽 한 솔 루 션 구현

3050 단어
즉, 저 는 100 개의 실행 가능 한 파일 이 있 는데 서로 특별한 선후 집행 관계 가 없습니다. 예 를 들 어 CODE:
 
  
job_1
job_2
job_2
.....
job_100

csh/bash 로 다 중 스 레 드 호출 을 수행 하려 고 합 니 다.
예 를 들 어 한 번 에 5 개의 스 레 드 를 열 면 job1, 2, 3, 4, 5 를 시작 하면 그 중의 모든 스 레 드 가 먼저 실행 되면 다음 에 실행 되 지 않 은 파일 을 계속 실행 합 니 다. 예 를 들 어 job6, 7, 8.....................................................................
나 는 원래 '&' 로 백 스테이지 에 넣 으 려 고 했 지만, 이렇게 하면 나 는 한 번 에 5 를 백 스테이지 에 넣 을 수 있 지만, 그 중 어떤 프로그램 이 언제 실 행 될 지 알 수 없 기 때문에 다음 프로그램 을 계속 실행 할 수 없다!
완벽 한 해결 방안:
 
  
-(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 ...
./job_4 exiting ...
./job_6 exiting ...
./job_10 starting ...
./job_10 sleeping for 5 seconds ...
./job_3 exiting ...
./job_8 exiting ...
./job_9 exiting ...
./job_10 exiting ...
-(dearvoid@LinuxEden:Forum)-(~/tmp)-
[$$=6718 $?=0] ; bye

좋은 웹페이지 즐겨찾기