Eventuate Tram Customers and Orders 开源项目教程

Eventuate Tram Customers and Orders 开源项目教程

eventuate-tram-examples-customers-and-orders An example of Choreography-based sagas in Spring Boot/JPA microservices eventuate-tram-examples-customers-and-orders 项目地址: https://gitcode.com/gh_mirrors/ev/eventuate-tram-examples-customers-and-orders

1. 项目介绍

Eventuate Tram Customers and Orders 是一个基于 Eventuate Tram 框架实现的微服务应用案例。该项目展示了如何在微服务架构中使用Saga模式和CQRS模式来维护数据一致性和提供高效的数据查询。

项目包含三个主要服务:

  • Order Service:管理订单,使用Saga模式处理跨服务的事务。
  • Customer Service:管理客户信息,并参与订单创建过程中的信用额度检查。
  • Order History Service:维护订单历史记录,使用CQRS模式从多个服务中获取数据。

2. 项目快速启动

快速启动本项目,你需要以下环境:

  • JDK 1.8+
  • Maven 3.5+
  • Docker

首先,克隆项目到本地:

git clone https://github.com/eventuate-tram/eventuate-tram-examples-customers-and-orders.git

然后,构建并运行项目:

# 使用 MySQL
./gradlew :end-to-end-tests:runApplicationMySQL

# 或者使用 Postgres
./gradlew :end-to-end-tests:runApplicationPostgres

以上命令将启动所有必要的服务,并打印出主页URL。

3. 应用案例和最佳实践

Saga模式

在创建订单时,Order Service 会创建一个处于 PENDING 状态的订单并发布 OrderCreated 事件。Customer Service 接收此事件并尝试为订单预留信用额度,发布 CreditReservedCreditLimitExceeded 事件。Order Service 根据接收的事件更新订单状态为 APPROVED 或 REJECTED。

CQRS模式

Order History Service 通过订阅 Order Service 和 Customer Service 发布的领域事件来维护一个基于 MongoDB 的CQRS视图。这个视图存储了每个客户的订单信息,以便提供高效的查询。

4. 典型生态项目

Eventuate Tram Customers and Orders 项目使用了以下典型生态项目:

  • Spring Boot:构建微服务的框架。
  • JPA:Java持久化API,用于数据持久化。
  • MySQL/Postgres:关系型数据库。
  • MongoDB:用于CQRS视图的NoSQL数据库。
  • Apache Kafka:事件发布和订阅的消息中间件。
  • Eventuate Tram:支持事务性消息传递的框架。

通过这个项目,开发者可以学习如何在微服务架构中实现复杂的事务处理和数据一致性保证。

eventuate-tram-examples-customers-and-orders An example of Choreography-based sagas in Spring Boot/JPA microservices eventuate-tram-examples-customers-and-orders 项目地址: https://gitcode.com/gh_mirrors/ev/eventuate-tram-examples-customers-and-orders

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吉昀蓓

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值