Java JSR 352-为什么<;可跳过的异常类>;停止工作

Java JSR 352-为什么<;可跳过的异常类>;停止工作,java,exception-handling,jsr352,Java,Exception Handling,Jsr352,我正在尝试使用JSR352和WebSphereLibertyProfile17.0.0.2创建一个简单的批处理应用程序。在进入异常处理之前,一切似乎都很正常。我假设job.xml中“skippable exception classes”节点中指定的应用程序引发的异常将被忽略/跳过,并允许作业继续执行下一个项目/步骤 每当调用注入bean的一个方法时从注入bean(通过@Inject)抛出异常时,就会出现我遇到的问题。作业仅在引发异常的当前项/步骤上停止 奇怪的是,每当我手动/显式抛出完全相同的

我正在尝试使用JSR352和WebSphereLibertyProfile17.0.0.2创建一个简单的批处理应用程序。在进入异常处理之前,一切似乎都很正常。我假设job.xml中“skippable exception classes”节点中指定的应用程序引发的异常将被忽略/跳过,并允许作业继续执行下一个项目/步骤

每当调用注入bean的一个方法时从注入bean(通过@Inject)抛出异常时,就会出现我遇到的问题。作业仅在引发异常的当前项/步骤上停止

奇怪的是,每当我手动/显式抛出完全相同的异常时,比如说RecordNotFoundException,作业就会继续,这正是我所期望的。只有当从注入的bean触发异常时,问题才会发生。我已将@ApplicationException添加到exception类中,以便将异常包装/展开到位

我错过什么了吗?这是WebSphereLiberty的一个bug吗

编辑:添加了简化代码

SampleSharedLibrary-来自其他项目/jar的依赖关系

package sample;

import javax.ejb.ApplicationException;
import javax.ejb.Stateless;

@Stateless
public class SampleSharedLibrary {

    public String someMethod(String object) {
        String result = null;

        if(object != null) {
            result = "OK";
        } else {
            throw new MyException();
        }

        return result;
    }

    @ApplicationException(rollback = true)
    public static class MyException extends RuntimeException {
        public MyException() {}
    }
}
批处理示例应用程序

取样员 导入sample.SampleSharedLibrary

import javax.batch.api.chunk.AbstractItemWriter;
import javax.enterprise.context.Dependent;
import javax.inject.Inject;
import javax.inject.Named;
import java.util.List;

@Dependent
@Named("SampleWriter")
public class SampleWriter extends AbstractItemWriter{

    @Inject
    SampleSharedLibrary sharedLibrary;

    public void writeItems(List<Object> list) throws Exception {
        for(Object item : list) {
            sharedLibrary.someMethod(item.toString());
        }
    }
}
EJB容器仍然可以回滚批处理区块事务,即使批处理容器跳过了给定的异常 将作业XML配置为跳过给定的异常只会阻止批处理容器将区块事务标记为回滚。它不会阻止其他人将事务标记为回滚

这意味着EJB容器本身可以回滚事务。因此,在您的情况下,您需要使用:

@ApplicationException(rollback = false)
public static class MyException extends RuntimeException {

或者,在预注释样式中,为了防止EJB容器回滚事务,您需要使用已检查的异常而不是未检查的异常。

欢迎使用Stackoverflow。请阅读如何创建一个最小的、完整的、可验证的示例。这听起来确实可能是RecordNotFoundException异常包装的问题。批处理容器代码查看它得到的异常,以查看它是否包含在可跳过列表中。它不会试图打开扔回它的东西。你能不能提供更多的细节,包括一段显示抛出异常的bean的代码片段?这是一个EJB还是一个CDIBean?你能分享你的服务器配置(server.xml)吗?我将尝试提供代码和一些额外的细节,不得不从代码中省略一些细节first@ScottKurz-添加了代码的简化版本和一些错误日志,希望可以理解
<job id="myJob" xmlns="http://xmlns.jcp.org/xml/ns/javaee" version="1.0">
    <step id="myStep" >
        <chunk item-count="1" skip-limit="50">
            <reader ref="SampleReader"/>
            <writer ref="SampleWriter"/>
            <skippable-exception-classes>
                <include class="java.lang.Exception"/>
                <include class="sample.SampleSharedLibrary$MyException"/>
            </skippable-exception-classes>
        </chunk>
    </step>
</job>
[02-11-17 21:38:12:323 CST] 000000d1 com.ibm.ws.logging.internal.impl.IncidentImpl                I FFDC1015I: An FFDC Incident has been created: "*******.**********.*******.batchflows.service.writer.ErrorWhileUpdating: *******.**********.*******.infrastructure.*****.commands.OurCommand$RecordNotFound: recordId=31AA69FAE017D21F com.ibm.jbatch.container.controller.impl.ChunkStepControllerImpl 485" at ffdc_17.11.02_21.38.12.0.log
[02-11-17 21:38:12:352 CST] 000000d1 com.ibm.ws.logging.internal.impl.IncidentImpl                I FFDC1015I: An FFDC Incident has been created: "com.ibm.jbatch.container.exception.BatchContainerRuntimeException: *******.**********.*******.batchflows.service.writer.ErrorWhileUpdating: *******.**********.*******.infrastructure.*****.commands.OurCommand$RecordNotFound: recordId=31AA69FAE017D21F com.ibm.jbatch.container.controller.impl.ChunkStepControllerImpl 1041" at ffdc_17.11.02_21.38.12.1.log
[02-11-17 21:38:12:363 CST] 000000d1 com.ibm.ws.logging.internal.impl.IncidentImpl                I FFDC1015I: An FFDC Incident has been created: "javax.transaction.RollbackException com.ibm.jbatch.container.transaction.impl.JTAUserTransactionAdapter 107" at ffdc_17.11.02_21.38.12.2.log
[02-11-17 21:38:12:385 CST] 000000d1 com.ibm.ws.logging.internal.impl.IncidentImpl                I FFDC1015I: An FFDC Incident has been created: "com.ibm.jbatch.container.exception.TransactionManagementException: javax.transaction.RollbackException com.ibm.jbatch.container.controller.impl.ChunkStepControllerImpl 680" at ffdc_17.11.02_21.38.12.3.log
@ApplicationException(rollback = false)
public static class MyException extends RuntimeException {