4

我现在正在将 SOS 调度程序从 sun solaris 迁移到 Oracle linux ,

SOS Berlin 调度程序是 1.5.3253 的最新版本 - Linux X64 和 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>

但是在结束作业之后,它可以转到下一个链继续,但只能运行第二个作业链的第一个作业。

是作业链上的配置错误吗?

任何想法 ?谢谢 !

4

1 回答 1

3

问题已确定。

错误如下:

<param name="ignore_stderr" value="1" />

以前我使用的是 1.3.x 版本。

现在升级到最新版本,变量名已更改。

解决方案如下:

<param name="scheduler_order_ignore_stderr" value="1"/>

然后工作将照常继续下一个。

于 2013-11-30T08:06:28.260 回答