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个统计语句,这样子就可以等于一次执行完成了。