SpringCloudAlibaba--Seata简单案例(三)

测试

数据库的初始情况:

  • seata_order.t_order:
    在这里插入图片描述

  • seata_storage.t_storage: 1号商品总数100,0个售出,实存100.
    在这里插入图片描述

  • seata_account.t_account: 1号用总金额1000,使用0,余额1000.
    在这里插入图片描述

正常下单

启动nacos、sentinel、seata以及2001、2002、2003微服务 :
在这里插入图片描述
访问:localhost:2001/order/create?userId=1&productId=1&count=10&money=100
在这里插入图片描述
订单表:
在这里插入图片描述
库存表:
在这里插入图片描述
账户:
在这里插入图片描述
正常下单成功。

超时异常,没加@GlobalTransaction

AccountServiceImpl添加超时:
在这里插入图片描述

再次访问:localhost:2001/order/create?userId=1&productId=1&count=10&money=100
在这里插入图片描述
报错,因为OpenFeign默认调用时限为1秒。

查看数据库:

订单表:插入了数据,但是因为accountService报错,所以status未修改
在这里插入图片描述
库存表:出现严重错误,下单失败商品不翼而飞…
在这里插入图片描述
账户表:出现严重错误,下单失败,但是扣钱了,钱货两空…
在这里插入图片描述

总结:当库存和账户金额扣减后,订单状态没有设置为已经完成,没有从0改为1,而且由于feign的重试机制,账户余额还有可能被多次扣减。

超时异常,添加@GlobalTransactional

在OrderServiceImpl上添加@GlobalTransactional
在这里插入图片描述

再次访问:localhost:2001/order/create?userId=1&productId=1&count=10&money=100
在这里插入图片描述
查看数据库:

订单表:未插入数据
在这里插入图片描述
库存表:未修改
在这里插入图片描述
账户表:未修改
在这里插入图片描述
结论:下单后数据库并没有任何改变,分布式事务控制成功。

发布了861 篇原创文章 · 获赞 2275 · 访问量 30万+

猜你喜欢

转载自blog.csdn.net/cold___play/article/details/105051581