java – SOS – 柏林调度程序无法继续下一份工作
作者:互联网
我现在正在将sun solaris的SOS调度程序迁移到Oracle linux,
SOS Berlin调度程序是1.5.3253的最新版本 – Linux X64 with
Java JDK 1.7.0.45 – 64位
上次使用JavaScript但64位不支持,所以我改为使用javax.script:javascript
很高兴每个工作都能够运行,但现在问题是,一旦第一个工作被触发,工作就不会继续下一个工作.
这是我更改的脚本:
<?xml version="1.0" encoding="UTF-8"?>
<job order="yes" title="F0001">
<params>
<param name="command" value="'/disk4/job/F0001 > /disk4/job/logs/F0001.log'"/>
<param name="ignore_error" value="0"/>
<param name="ignore_signal" value="0"/>
<param name="ignore_stderr" value="1"/>
<param name="log_file" value="/disk4/job/logs/F0001.log"/>
<param name="timeout" value=""/>
<param name="interpreter" value="/bin/ksh"/>
</params>
<script
java_class="sos.scheduler.managed.JobSchedulerManagedExecutableJob" language="java"/>
<monitor>
<script language="javax.script:javascript">
function spooler_task_after(){
var exitCode = spooler_task.exit_code();
if(exitCode != 0){
spooler_log.info("Program exit with exit code : " + exitCode);
return false;
}
return true;
}
</script>
</monitor>
</job>
这是我的工作链:
<?xml version="1.0" encoding="UTF-8"?>
<job_chain title="001_DAILY">
<job_chain_node error_state="error" job="F0001" next_state="1" state="0"/>
<job_chain_node error_state="error" job="F0002" next_state="2" state="1"/>
<job_chain_node error_state="error" job="F0003" next_state="success" state="2"/>
<job_chain_node job="001_END" state="success"/>
<job_chain_node.end state="error"/>
</job_chain>
这是我的最终工作:
<?xml version="1.0" encoding="utf-8"?>
<job order="yes" title="001_END">
<params>
<param name="command" value="'echo DONE > /disk4/job/logs/001_END.log'"/>
<param name="ignore_error" value="0" />
<param name="ignore_signal" value="0" />
<param name="ignore_stderr" value="1" />
<param name="interpreter" value="/bin/ksh" />
<param name="log_file"
value="/disk4/job/logs/tmp_job_stdout.log" />
<param name="timeout" value="" />
</params>
<script java_class="sos.scheduler.managed.JobSchedulerManagedExecutableJob"
language="java" />
<monitor>
<script language="javax.script:javascript">
function spooler_task_after(){
return true;
}
</script>
</monitor>
<commands on_exit_code="success">
<add_order id="002_ROUTINE" job_chain="/002_ROUTINE_A" replace="yes"/>
</commands>
</job>
但是在完成最终工作之后,它将能够继续下一个连锁店,但只能运行第二个工作链的第一份工作.
作业链上的配置错误是什么?
任何的想法 ?谢谢 !
解决方法:
问题得到确认.
错误如下:
<param name="ignore_stderr" value="1" />
以前我使用的是1.3.x版本.
现在升级到最新版本并更改变量名称.
解决方案如下:
<param name="scheduler_order_ignore_stderr" value="1"/>
然后工作将继续正常.
标签:java,linux,javax-script 来源: https://codeday.me/bug/20190629/1324219.html