订单系统架构 学习笔记

订单系统架构 学习笔记

基础篇

当结算时,结算页触发下单服务,数据存放在数据库中,异构到缓存中提供用户查询操作。

当收银台支付完成时,同样会触发下单服务,修改数据库和缓存中的数据。

在这里插入图片描述
注:
1.关键逻辑不要使用读写分离的的查询方法,避免从库延迟造成订单查询异常。
如:创建订单之后要创建支付单,但在反查订单时,由于主从延迟未查到订单信息,就会造成支付单创建失败
在这里插入图片描述
2.关键逻辑不要使用缓存做订单查询,避免缓存延迟造成订单反查失败。
在这里插入图片描述
3.订单补偿不能粗暴使用消息队列,避免中间件引发订单丢失。

在这里插入图片描述
4.接收消息失败时一定要让消息重试,避免丢失,且要注意return和continue等关键字,避免在一条条处理消息的过程中,因为关键字丢失后续所有消息。
在这里插入图片描述
5.写数据库时,数据库事务粒度不要太大,避免锁表,关注慢SQL。
如:在数据库事务中同时更新其他数据源和发送消息到消息中,这不能保证数据一致性还会耗尽数据库连接
在这里插入图片描述
6.关注数据异构的性能和稳定性,尤其是在网络抖动的情况下。

7.留意订单系统幂等性,避免产生计费等错误。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值