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