【shell】串行执行批量任务脚本
程序员文章站
2022-06-08 20:34:15
...
前阵放假时候,帮人跑实验,需要在一台服务器上跑一堆java实验程序。
为了实验结果的公正性,要保证每次只跑一个实验,也就是需要串行的跑完所有java程序。
刚开始的时候,我每跑一个程序,隔一段时间去服务器上检查一下是否跑完,需要时时留意,实在有点不爽,人也不能走开。
于是写了个shell脚本:串行的去执行一批java程序任务列表。
过程如下:
1.新建任务列表
以实验为例的tasklist.txt:
java -cp fastPPV0318.jar -Xms512m -Xmx1024m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG1O1.properties fanwei.ppv.preprocess.hubselection.HybridG1O1Selection 1 1 dblp > dblpHybridG1O1Selection.log java -cp fastPPV0318.jar -Xms512m -Xmx1024m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG1O1.properties fanwei.ppv.preprocess.hubselection.HybridG1O1Selection 0.5 1 dblp > dblpHybridG1O1Selection.log java -cp fastPPV0318.jar -Xms512m -Xmx1024m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG1O1.properties fanwei.ppv.preprocess.hubselection.HybridG1O1Selection 1 2 dblp > dblpHybridG1O1Selection.log java -cp fastPPV0318.jar -Xms1024m -Xmx2048m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG1O1.properties fanwei.ppv.execution.LocalPPVSerializerMain > dblpHybridG1O1LocalPPV.log java -cp fastPPV0318.jar -Xms1024m -Xmx2048m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG0.5O1.properties fanwei.ppv.execution.LocalPPVSerializerMain > dblpHybridG0.5O1LocalPPV.log java -cp fastPPV0318.jar -Xms1024m -Xmx2048m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG1O2.properties fanwei.ppv.execution.LocalPPVSerializerMain > dblpHybridG1O2LocalPPV.log java -cp fastPPV0318.jar -Xms1024m -Xmx2048m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG1O1.properties fanwei.ppv.execution.OnlineQueryProcess > dblpHybridG1O1Query.log java -cp fastPPV0318.jar -Xms1024m -Xmx2048m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG0.5O1.properties fanwei.ppv.execution.OnlineQueryProcess > dblpHybridG0.5O1Query.log java -cp fastPPV0318.jar -Xms1024m -Xmx2048m -Dppv.config=/home/zhufw/fastppv/config/ppv_dblp_30000_hybridG1O2.properties fanwei.ppv.execution.OnlineQueryProcess > dblpHybridG1O2Query.log
2.编写串行批量运行脚本
batchRun.sh:
#!/bin/bash if [ "$1" = "" ] ; then echo "Bad command. No tasklist file been appointed. Right format: $0 [tasklist.txt]" exit 1 fi tasks=`cat $1|wc -l` echo "total tasks founded:$tasks" echo "Now begin running....." cat $1|while read line do tasks=`jps|wc -l` while [ $tasks -gt 1 ] do sleep 20 echo "task is running" tasks=`jps|wc -l` done $line & echo "running $line" sleep 5 done echo "end."
以上脚本只是简单的一个脚本,会依次读取tasklist.txt里的任务,并每隔20秒检查一下是否有java程序在运行,如果没有,则执行当前读取到的任务,否则循环检查。
3.执行脚本
./batchRun.sh tasklist.txt > batchRun.log &
OK,白天可以和朋友出去玩了,晚上回来检查结果。
脚本很简单,也不完美,有很大局限性,不过让机器去胜任,能很大提升效率。
下一篇: 【shell】串行执行批量任务脚本