编程语言
首页 > 编程语言> > java – SOS – 柏林调度程序无法继续下一份工作

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