如何在Unix Shell脚本中进行并行处理?
我有一个
shell脚本,它将build.xml文件传输到远程unix机器(devrsp02)并在该机器上执行ANT任务wldeploy(devrsp02).现在,这个wldeploy任务大约需要15分钟才能完成,在运行时,unix控制台的最后一行是 –
完成此任务后,我们将获得“任务已完成”消息,并且脚本中的下一个任务仅在此之后执行. 但有时,weblogic域可能存在问题,部署可能在内部失败,对wldeploy任务的状态没有影响. unix控制台仍将停留在“task {some digit} initialized”.部署错误将记录在名为output.a的文件中 那么,我现在想要的是 – 在运行wldeploy之前启动时间计数器.如果wldeploy运行超过15分钟,则应运行以下命令 –
要么
这里需要注意的是 – 我无法在后台运行wldeploy任务,因为在这种情况下,用户将无法知道任务何时完成,这对此脚本至关重要. 你能提出一些建议吗?
创建此脚本(例如deploy.sh):
#!/bin/sh sleep 900 && pkill -n wldeploy && cat output.a & wldeploy 然后从控制台 chmod +x deploy.sh 然后跑 ./deploy.sh 这个脚本将启动一个计数器(15分钟),如果它正在运行,将强制终止wldeploy进程,如果进程正在运行,你将看到output.a的内容. 如果脚本已终止,那么pkill将不会返回true,并且output.a将不会显示. 我会把这个任务称为监控而不是“并行处理”:) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |