news 2026/4/22 21:45:23

案例:热点账户扣减架构设计

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
案例:热点账户扣减架构设计

背景

在大型系统中,热点账户更新是高并发场景下,一个典型场景。如何在高并发的情况下,实现低延迟和数据一致性,是架构师需要面临的挑战。

本文抛弃了外延的流量控制,监控等内容,主要从DB和缓存的角度来讲。

分析

高并发从字面理解,首先是解决并发的问题,并发会导致什么问题呢?

1、流量大,导致响应时间长、甚至压垮系统。

思路:分散流量、平滑流量、限制流量。

解决:流量控制、系统拆分、缓存、异步等,

2、造成数据的不一致。

思路:强一致、弱一致、最终一致。

解决:事务、锁、MQ、对账等。

方案1:数据库乐观锁

在并发量不大,比如100~1000,使用数据库乐观锁是最简单,最方便的方式。

update account set amout=amout-100 where version=10 and amount-100>0

核心:加版本号、判断账户金额不要小于0

方案2:Redis扣减,异步合并

随着并发量变大,比如<5000,单纯使用数据库乐观锁就不行了,会导致数据库宕机。比较简单的方案是,缓存扣减。所有扣减走Redis缓存,再异步到数据库中。

1、扣减日志:写扣减日志【可写文件或DB库-本地表,文件性能会更高】

2、Redis扣减:Redis账户金额扣减。

3、异步汇总:调度30秒~1分钟,同步一次数据库,更新Redis【可乐观锁或分布式锁控制】。

方案3:数据分片,异步合并

随着业务发展,并发量爆发,比如在1万,10万等,此时需要对系统进行深度改造。

1、DB拆分:账户表,拆分为N个账户表,比如1~128张表。【可能涉及分库】

2、缓存扣减:将数据分片到多个redis实例或本地服务器缓存,用于扣减。

3、异步汇总:调度30秒~1分钟,同步一次数据库,更新Redis或本地缓存。【可乐观锁或分布式锁控制】

4、中心调度:有一个调度中心,监控各分片的数据,进行扣减调度,比如表1金额不足,要实时路由到满足扣减要求的表。【需要分布式锁控制】

其它方案:MQ异步+批量扣减

1、扣减请求:Reis扣减,写MQ

2、批量扣减:消息端批量拉取扣减记录,计算金额后,一次性扣减账户记录。

关于读

上面解决了高并发写和数据一致性问题。关于用户读如何实现呢?

1、读缓存,缓存定时与DB对账同步;

2、页面允许少量延迟,提供一个刷新按钮,刷新后显示。

总结

本文介绍了高并发典型场景,热点账户扣减的常见方案,可以根据实际场景进行组合选择。

https://mp.weixin.qq.com/s/9B6j-iwDyoK6gnXs1QR8dQ

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 1:36:51

一文带你快速了解大模型推理优化

一文搞懂大模型推理优化 前言 大模型的落地应用中&#xff0c;推理环节是绕不开的核心——不管是智能问答、文本生成还是图像理解&#xff0c;模型的推理速度和显存占用直接决定了应用的用户体验和部署成本。动辄数十亿、上百亿参数的大模型&#xff0c;在普通硬件上推理时往…

作者头像 李华
网站建设 2026/4/18 8:38:26

为什么经济学里有那么多数学公式?

要深入理解 “经济学里数学公式多” 的现象&#xff0c;需要从 **“工具的合理必要性”“学术生态的非理性内卷”** 两个层面结合分析 —— 前者解释了数学公式 “为何存在”&#xff0c;后者解释了数学公式 “为何过多甚至泛滥”&#xff0c;二者共同构成了当前经济学中数学公…

作者头像 李华
网站建设 2026/4/17 20:02:37

python基于vue的汽车租赁系统的续租django flask pycharm

目录 基于Vue与Python的汽车租赁系统续租功能实现 开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 基于Vue与Python的汽车租赁系统续租功能实现 技术栈组合 系统采用前后端分离架构&#x…

作者头像 李华
网站建设 2026/4/18 7:35:17

java学习--LinkedHashSet

一、LinkedHashSet 是什么&#xff1f;LinkedHashSet 是 Java 集合框架中 java.util 包下的实现类&#xff0c;它继承自 HashSet&#xff0c;同时实现了 Set 接口&#xff0c;底层基于 LinkedHashMap 实现&#xff08;本质是「哈希表 双向链表」&#xff09;。可以把它理解为&…

作者头像 李华