9.3. saga 服务配置
Saga EIP 要求实施接口 org.apache.camel.saga.CamelSagaService
的服务添加到 Camel 上下文中。Camel 目前支持以下 Saga 服务:
- InMemorySagaService :这是 Saga EIP 的基本 实现,它不支持高级功能(没有远程上下文传播,在应用程序失败时没有一致性保证)。
9.3.1. 使用内存 Saga 服务
在生产环境中不建议使用内存中 Saga 服务,因为它不支持 Saga 状态的持久性(仅保留在内存中),因此它不能保证 Saga EIPs 在应用程序故障时的一致性(例如 JVM 崩溃)。另外,在使用内存 Saga 服务时,无法使用传输级标头将 Saga 上下文传播到远程服务(它可以通过其他实现完成)。如果要使用内存 saga 服务,您可以添加以下代码来自定义 Camel 上下文。该服务属于 camel-core
模块。
context.addService(new org.apache.camel.impl.saga.InMemorySagaService());