Spring Batch:如何在步骤侦听器中使用占位符?

时间:2010-11-08 18:27:51

标签: java spring-batch

<beans>
<batch:job id="job1" restartable="false">
  <batch:step id="step1" next="step2">
    <batch:tasklet>
      <batch:chunk reader="readerA" writer="writerA" commit-interval="1" />
    </batch:tasklet>
  </batch:step>
  <batch:step id="step2">
    <batch:tasklet ref="tasklet1"/>
  </batch:step>
  <batch:listeners>
    <batch:listener ref="listenerA" />
  </batch:listeners>
</batch:job>

<bean id="listenerA" class="com.example.ListenerA" scope="step">
  <property name="archiveDate" value="#{jobParameters['jobRunDate']}" />
</bean>
</beans>

为什么上面给出了以下错误:

java.lang.IllegalStateException: No context available while replacing placeholders.

解决此问题的最佳方法是什么?

1 个答案:

答案 0 :(得分:3)

我认为问题在于你想要一个步骤监听器,而不是一个求职者。步骤范围超出了您定义监听器的范围,因此范围步骤不可用 - 如果它是作业监听器,您将不需要占位符,因为您可以从当前JobExecution获取变量。

如果你改变了你的配置(假设这是一个步骤监听器,而不是一个工作监听器):

<batch:step id="step1" next="step2">
<batch:tasklet>
  <batch:chunk reader="readerA" writer="writerA" commit-interval="1" />
  <batch:listeners>
      <batch:listener ref="listenerA" />
 </batch:listeners>
</batch:tasklet>
</batch:step>

我相信这会给你一个适当的步骤监听器,用于“step1”步骤 - 如果你想要第二步的监听器那么类似的配置。