我有一个 Spring Batch 进程,它在数据库中获取一组行并从这些行创建许多平面文件,每个文件 10 行。为此,我创建了一个 Spring Batch 流程,类似于:
<batch:job id="springTest" job-repository="jobRepository" restartable="true">
    <batch:step id="test">
        <batch:tasklet>
            <batch:chunk reader="itemReader" writer="multipleItemWriter" commit-interval="2" />
        </batch:tasklet>
    </batch:step>
</batch:job>
<bean id="itemReader" class="org.springframework.batch.item.file.FlatFileItemReader">
    <property name="resource" value="file:/temp/temp-input.txt" />
    <property name="lineMapper">
        <bean class="org.springframework.batch.item.file.mapping.PassThroughLineMapper" />
    </property>
</bean>
<bean id="multipleItemWriter" class="org.springframework.batch.item.file.MultiResourceItemWriter">
    <property name="resource" value="file:/temp/temp-out" />
    <property name="itemCountLimitPerResource" value="2" />
    <property name="delegate">
        <bean id="itemWriter" class="org.springframework.batch.item.file.FlatFileItemWriter">
            <property name="lineAggregator">
              <bean class="org.springframework.batch.item.file.transform.PassThroughLineAggregator" />
            </property>
            <property name="encoding" value="utf-8" />
            <property name="headerCallback" ref="headerFooter" />
            <property name="footerCallback" ref="headerFooter" />
        </bean>
   </property>
</bean>
<bean id="headerFooter" class="uk.co.farwell.spring.HeaderFooterCallback" />
上面的示例从平面文件中读取并输出到平面文件(以显示问题)。请注意块中的 commit-interval=2,以及 MultiResourceItemWriter 中的 itemCountLimitPerResource=2。
HeaderFooterCallback 执行以下操作:
public void writeHeader(Writer writer) throws IOException {
    writer.write("file header\n");
}
public void writeFooter(Writer writer) throws IOException {
    writer.write("file footer\n");
}
我需要能够准确指定文件中出现的行数。
对于以下输入文件:
foo1
foo2
foo3
我希望输出有两个文件,
出.1:
file header
foo1
foo2
file footer
出.2:
file header
foo3
file footer
当我以 commit-interval=2 运行时,出现异常:
2009-11-26 15:32:46,734 ERROR .support.TransactionSynchronizationUtils - TransactionSynchronization.afterCompletion threw exception
org.springframework.batch.support.transaction.FlushFailedException: Could not write to output buffer
    at org.springframework.batch.support.transaction.TransactionAwareBufferedWriter$1.afterCompletion(TransactionAwareBufferedWriter.java:71)
    at org.springframework.transaction.support.TransactionSynchronizationUtils.invokeAfterCompletion(TransactionSynchronizationUtils.java:157)
    at org.springframework.transaction.support.AbstractPlatformTransactionManager.invokeAfterCompletion(AbstractPlatformTransactionManager.java:974)
    .
    .
    .
Caused by: java.io.IOException: Stream closed
    at sun.nio.cs.StreamEncoder.ensureOpen(Unknown Source)
    at sun.nio.cs.StreamEncoder.write(Unknown Source)
    at sun.nio.cs.StreamEncoder.write(Unknown Source)
    at java.io.Writer.write(Unknown Source)
    at org.springframework.batch.support.transaction.TransactionAwareBufferedWriter$1.afterCompletion(TransactionAwareBufferedWriter.java:67).
我认为这是一个错误。奇怪的是,文件如下:
出.1:
file header
foo1
foo2
出.2:
file footer
如果我在输入文件中有两行,一切正常,但多于两行不起作用。如果我将提交间隔更改为 200,那么我会在一个文件中得到三行,这不是想要的行为。
如果有人能告诉我我做错了什么,或者如果不是如何解决这个问题,我将非常感激。