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());