订单系统架构 学习笔记
基础篇
当结算时,结算页触发下单服务,数据存放在数据库中,异构到缓存中提供用户查询操作。
当收银台支付完成时,同样会触发下单服务,修改数据库和缓存中的数据。
注:
1.关键逻辑不要使用读写分离的的查询方法,避免从库延迟造成订单查询异常。
如:创建订单之后要创建支付单,但在反查订单时,由于主从延迟未查到订单信息,就会造成支付单创建失败
2.关键逻辑不要使用缓存做订单查询,避免缓存延迟造成订单反查失败。
3.订单补偿不能粗暴使用消息队列,避免中间件引发订单丢失。
4.接收消息失败时一定要让消息重试,避免丢失,且要注意return和continue等关键字,避免在一条条处理消息的过程中,因为关键字丢失后续所有消息。
5.写数据库时,数据库事务粒度不要太大,避免锁表,关注慢SQL。
如:在数据库事务中同时更新其他数据源和发送消息到消息中,这不能保证数据一致性还会耗尽数据库连接
6.关注数据异构的性能和稳定性,尤其是在网络抖动的情况下。
7.留意订单系统幂等性,避免产生计费等错误。
版权声明:本文为qq_40382179原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。