如何在Unix Shell脚本中进行并行处理?

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任务,因为在这种情况下,用户将无法知道任务何时完成,这对此脚本至关重要.

你能提出一些建议吗?

And*_*ndy 3

创建此脚本(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不会显示。

我会将此任务称为监视而不是“并行处理”:)