Bik*_*wal 5 unix ant parallel-processing shell weblogic-10.x
我有一个shell脚本,它将build.xml文件传输到远程unix机器(devrsp02)并在该机器上执行ANT任务wldeploy(devrsp02).现在,这个wldeploy任务大约需要15分钟才能完成,在运行时,unix控制台的最后一行是 -
"任务{some digit} initialized".
完成此任务后,我们将获得"任务已完成"消息,并且脚本中的下一个任务仅在此之后执行.
但有时,weblogic域可能存在问题,部署可能在内部失败,对wldeploy任务的状态没有影响.unix控制台仍将停留在"task {some digit} initialized".部署错误将记录在名为output.a的文件中
那么,我现在想要的是 -
在运行wldeploy之前启动时间计数器.如果wldeploy运行超过15分钟,则应运行以下命令 -
tail -f output.a ##不终止wldeploy
要么
cat output.a ##强行终止wldeploy之后
这里需要注意的是 - 我无法在后台运行wldeploy任务,因为在这种情况下,用户将无法知道任务何时完成,这对此脚本至关重要.
你能提出一些建议吗?
创建此脚本(deploy.sh例如):
#!/bin/sh
sleep 900 && pkill -n wldeploy && cat output.a &
wldeploy
Run Code Online (Sandbox Code Playgroud)
然后从控制台
chmod +x deploy.sh
Run Code Online (Sandbox Code Playgroud)
然后运行
./deploy.sh
Run Code Online (Sandbox Code Playgroud)
该脚本将启动一个计数器(15 分钟),wldeploy如果该进程正在运行,该计数器将强制终止该进程,如果该进程正在运行,您将看到output.a.
如果脚本已终止,则pkill不会返回 true 并且output.a不会显示。
我会将此任务称为监视而不是“并行处理”:)