Shell多线程执行脚本示例

Shell脚本是顺序执行的,但是系统允许多个Shell脚本同时执行,为了达到资源的综合利用,也就是把服务器往死里用,有时候需要一段脚本对多个脚本进行多线程的调度,并且等待完成之后继续执行后续的脚本。
 
主脚本:
# !/bin/bash
#用于识别子线程的完成数量
rm test.count
touch test.count
#开始启动子线程
./script.sh 10 &
./script.sh 20 &
./script.sh 30 &
./script.sh 40 &
./script.sh 50 &
./script.sh 60 &
./script.sh 70 &
./script.sh 80 &
#监控子线程的完成数量
v_count=`wc -l test.count | awk -F ' ' '{print $1}'`
while [[ ${v_count} -lt 8 ]];do
    echo $i;
echo "子脚本还没有完全执行完毕,已完成:${v_count}"
v_count=`wc -l test.count | awk -F ' ' '{print $1}'`
sleep 1
done;
echo "子脚本完全执行完毕,已完成:${v_count}"
 
 
子脚本:
# !/bin/bash
 
id=${1}
 
for((i = 0 ;i < ${id} ;i ++ )); do
{
    echo " ${id} Children ${i}."
sleep 1;
}
done
echo "finish">>test.count
 
通过上面的方法,即可把服务器往死里用了,这个在多维度统计报表数据的时候特别有用,3个维度的报表需要8个统计语句,这样子就可以等于一次执行完成了。

猜你喜欢

转载自hoochiang.iteye.com/blog/2271547