- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 Camel 的事务管理有疑问。
在我的示例中,我从 ZIP 中提取了一个 XML 文件,通过 JAXB 从 xml 中创建了一个 JPA 实体并将其写入数据库。然后我强制执行 RuntimeException。
我的期望是回滚插入的实体,但它们已经提交。
我在 ZIP 拆分器上放置了一个事务处理调用,以便处理所有包含的文件或不处理。聚合器负责在将元数据写入数据库之前将来自不同文件的元数据组合起来。
谁能解释一下代码中缺少什么或者我对 Camel 事务管理的误解在哪里?
提前致谢
阿德里安
...
private final class AggregationStrategyImplementation implements AggregationStrategy {
DocumentMetaDataContainer documentMetaDataContainer;
public Exchange aggregate(Exchange oldExchange, Exchange newExchange) {
if (oldExchange == null) {
documentMetaDataContainer = (DocumentMetaDataContainer) newExchange.getIn()
.getBody();
oldExchange = newExchange;
} else {
String header = String.valueOf(newExchange.getIn().getHeader("CamelFileName"));
System.out.println("aggregating " + header);
documentMetaDataContainer.putFileStreamToSpecificElement(header, newExchange
.getIn().getBody(byte[].class));
if (isDone()) {
oldExchange.getOut().setHeader(Exchange.AGGREGATION_COMPLETE_ALL_GROUPS, true);
}
}
return oldExchange;
}
public boolean isDone() {
if (documentMetaDataContainer == null)
return false;
for (DocumentMetaData documentMetaData : documentMetaDataContainer
.getListOfDocumentMetaData()) {
if (documentMetaData.getDocumentFile() == null)
return false;
}
return true;
}
}
public void processImport() throws Exception {
ApplicationContext springContext = new ClassPathXmlApplicationContext(
"classpath:spring.xml");
final CamelContext camelContext = SpringCamelContext.springCamelContext(springContext);
RouteBuilder routeBuilder = new RouteBuilder() {
private static final String inbox = "/Development/ppaFiles";
JAXBContext jaxbContext = JAXBContext.newInstance(new Class[] {
com.business.services.DocumentMetaDataContainer.class
});
DataFormat jaxbDataFormat = new JaxbDataFormat(jaxbContext);
public void configure() {
from("file:"+inbox+"?consumer.delay=1000&noop=true")
.routeId("scanDirectory")
.choice()
.when(header("CamelFileName").regex("badb_(.)*.zip"))
.setHeader("msgId").simple("${header.CamelFileName}_${date:now:S}")
.log("processing zip file, aggregating by ${header.msgId}")
.to("direct:splitZip")
.end();
from("direct:splitZip")
.routeId("splitZip")
.transacted()
.split(new ZipSplitter())
.streaming()
.choice()
.when(header("CamelFileName").regex("(.)*_files.xml")) // Meta File
.to("direct:toDocumentMetaData")
.otherwise() // PDF XML Files
.to("direct:toByteArray")
.end();
from("direct:toByteArray")
.routeId("toByteArray")
.convertBodyTo(byte[].class)
.to("direct:aggregateZipEntries");
from("direct:toDocumentMetaData")
.routeId("toDocumentMetaData")
.split()
// root tag name in xml file
.tokenizeXML("files")
.unmarshal(jaxbDataFormat)
.to("direct:aggregateZipEntries");
from("direct:aggregateZipEntries")
.routeId("aggregateZipEntries")
// force to start with meta data file ('..._files.xml')
.resequence(simple("${header.CamelFileName.endsWith('_files.xml')}"))
.allowDuplicates()
.reverse()
.aggregate(new AggregationStrategyImplementation())
.header("msgId")
.completionTimeout(2000L)
.multicast()
.to("direct:saveDocumentMetaData", "direct:doErrorProcessing");
from("direct:saveDocumentMetaData")
.routeId("saveDocumentMetaData")
.split(simple("${body.listOfDocumentMetaData}"))
.multicast()
.to("jpa://com.business.persistence.entities.DocumentMetaData"+
"?persistenceUnit=persistenceUnit"+
"&consumer.transacted=true"+
"&transactionManager=#transactionManager"+
"&flushOnSend=false")
.log("processDocumentMetaData: ${body.getName()}");
from("direct:doErrorProcessing")
.routeId("doErrorProcessing")
.process(new Processor() {
public void process(Exchange exchange) throws Exception {
throw new RuntimeException("Error");
}
});
}
};
camelContext.addRoutes(routeBuilder);
camelContext.start();
Thread.sleep(10000);
camelContext.stop();
}
...
最佳答案
似乎在“splitZip”路由中创建的事务直到“saveDocumentMetaData”和“doErrorProcessing”中的保存事件才扩展,perhaps due to using an aggregator without a persistent store .这就是为什么在“doErrorProcessing”中抛出的异常不会导致“saveDocumentMetaData”中的回滚。
要在一个事务中包含“saveDocumentMetaData”和“doErrorProcessing”,为多播创建一个新事务:
// ...
.aggregate(new AggregationStrategyImplementation())
.header("msgId")
.completionTimeout(2000L)
.to("direct:persist");
// new transacted route
from("direct:persist")
.routeId("persist")
.transacted()
.multicast()
.to("direct:saveDocumentMetaData", "direct:importBalanceSheet");
关于java - Apache Camel : No rollback after RuntimeException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22913796/
我真的很难弄明白这一点。当我查看 logcat 指向错误的位置时,它指向这一行: throw new RuntimeException(i); 在里面 public void onDetach() {
@Transactional (noRollbackFor=RuntimeException.class) public void methodA (Entity e){ service.met
我正在开发简历应用程序并遇到以下异常 在gradle文件上,我尝试了所有可能的解决方案,使缓存重启无效,并且干净的gradle不起作用 java.lang.RuntimeException:java.
我的项目在 Android Studio 3.0.1 上的 Whatchap 中,这是我的设计 gradle。build.gradle(应用程序) 应用插件:'com.android.applicat
// Top-level build file where you can add configuration options common to all sub-projects/modules.
您好,目前我正在开发包括解析服务器的项目,并且在将解析库添加到我的项目后,当我运行它时,它显示此错误,任务“:app:checkDebugDuplicateClasses”执行失败。 Exec
我找到了 another post显示我们如何创建我们自己的检查异常,它也返回不同于 500 的 HTTP 状态代码。但是,我需要它是一个 RuntimeException。然后,我找到了WebApp
我尝试在 7.40 系统上演示具有动态方法名称的 CALL METHOD 语句。我使用下面的测试代码,在第 27 行得到一个 ABAP 运行时错误。异常描述中的错误分析状态 ... 在类 LCL 中,
我的ViewModel类抛出了RunTimeException。它基本上不能创建ViewModel类的实例。这是堆栈跟踪: 2019-05-29 01:27:56.700 9698-9698/com.
我安装了Hive 0.9.0,运行它时出现错误: ./hive Logging initialized using configuration in jar:file:/usr/lib/hive-0.
当我尝试在 android 4.1.1(galaxy nexus)上运行 opencv(2.4.2) sample3时。我收到RuntimeException。 Logcat指向此处:(android
Java中除了RuntimeException之外还有其他可能发生的异常吗?谢谢。 最佳答案 是的,有三种种。 检查异常 编译器会让您知道何时可以抛出它们,很可能是由于环境中的故障。 如果程序可以
这个问题已经有答案了: Why runtime exception is unchecked exception? (5 个回答) 已关闭 7 年前。 我知道受检查的异常继承自 Exception并且
这里发生了什么? 为什么 IOException (RemoteException) 的检查子级会转换为 RuntimeException? 摘自here的片段 import java.rmi.Rem
源代码(osmand)没有错误 我使用了 eclipse 和 sdk 模拟器 2.2,从 googlecode checkout (osmand应用程序) 我的代码: public void onCr
我开始研究线程,我不明白为什么下面的简单代码不起作用。它正在抛出: RuntimeException: can't create handler inside thread that has not
我想为自己破例。但是当我抛出异常时,程序就关闭了。那么我怎样才能运行我的方法3次然后关闭程序呢? (我的程序在intArray之后关闭,但我想遍历dobleArray和charArray) 这是我的异
我有一个扩展 HttpServlet 的类包含以下两个方法。当客户端向 Tomcat 服务器上运行的 Web 应用程序发出请求时,http 请求将通过此类处理,但是如果 doSomething 方法抛
在很多地方,我都会遇到几个检查异常,例如 IOException、ParseException、JSONException 等。我必须做出两个选择 - 通过在方法签名末尾添加 throws 来引发相同
RuntimeExceptions 应该指示编程错误,我希望我的应用程序在我的可观察对象中的某些东西抛出 RuntimeException 时崩溃。 最好的方法是什么?现在我正在考虑这个解决方案(它是
我是一名优秀的程序员,十分优秀!