分布式事务测试与异常模拟详解
在分布式系统中,事务处理是一个复杂且关键的问题。本文将详细介绍一系列分布式事务的测试场景,包括事务回滚、消息丢失、重复消息发送等情况,帮助你更好地理解和应对分布式事务中的各种挑战。
1. 事务语义基础
在测试中,我们对所有服务方法应用了 TX_REQUIRED 事务语义。这意味着资源中的状态更改要么全部完成,要么全部回滚。在当前测试用例中,由于未模拟任何错误或失败条件,所有事务均成功执行。
2. 事务回滚场景测试
为了测试事务回滚场景,我们使用 Postman 创建一个新的报价:
{
"symbol": "AMZN",
"sellerId": 11,
"buyerId": 21,
"amount": 200,
"test": 2,
"delay": 2
}
请求地址为: http://localhost:8080/api/quotes ,请求方法为 POST 。
在执行过程中,当 Quotes Processor Task 第一次处理新报价时,我们在 broker service 中模拟一个错误。此时,尽管 auction service 和 stock order service 中的相应事务已准备好提交,但由于它们是在模拟错误的
超级会员免费看
订阅专栏 解锁全文
1334

被折叠的 条评论
为什么被折叠?



