首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
搜索
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
黄小闹
大连交通大学 Java
发布于北京
关注
已关注
取消关注
@JavaEdge:
支付账务清结算系统设计
1 账务清结算系统职责概述账务清结算系统是支付系统的资金控制管理模块,分为:1.1 账务账务系统为外部客户和内部管理者提供符合公司内部财务核算的各种会计凭证、账簿与财务报表,一般分为:实时入账模块,负责在线完成客户账户余额更新日终批处理模块,负责日终余额校验并完成会计报表统计1.2 清结算支付业务的资金计算模块,最终目的是实现与商户的货款两清,功能包括:**清算(Clearing)**是根据交易结果和协议规定,对交易的客户备付金、商户手续费、银行成本和其他款项进行计算,明确每个客户的应收应付金额**结算(Settlement)**是根据结算周期规定,对清算产生的应收应付金额,完成资金的划拨;对账最终完成货款两清**对账(Statement)**过程中交易成员对收付的结算款项核对、确认,确保自身权益不受影响2 建设重点账务清结算系统承接支付的所有交易的资金处理。除了满足基本结算业务规则和财务会计规则,还需根据互联网支付业务特点,额外考虑:实时交易,交易总量大,交易峰值不可控KA 商户模式,数据库存在热点账户问题,并且资金数据是敏感数据,要求绝对的准确,所以数据库表拆分方案复杂结算模式多样,千人千面结算计费规则3 系统功能架构三方支付场景中,账务和清结算是交易的必要一环,入账和清结算请求,来自交易支付系统。3.1 支付交易的标准入账结算信息流交易支付系统分别通知账务、清结算模块,完成交易入账、交易清结算处理,清结算完成结算后再次调用入账完成结算款划拨。那么,为啥要分开并行完成交易入账和清结算请求呢?账务的维度和交易的资金出入要一一对应,组合支付、合单支付场景,一笔支付不能完全对应一笔结算,需在支付交易系统明确订单拆分规则,依商户订单模式报送清结算,依支付订单维度报送账务账务和清结算分开,可在内部做一个弱校验,即使其中一个系统出问题,也可保证不产生资损,降低资金风险账务清结算系统接收到支付的指令后,根据业务流程、账务规则和结算规则,设计账务清结算系统的组成结构:一、前置接口 对外系统提供不同的协议服务,以完成账务入账和结算逻辑。主要处理:流量控制:对接口流量控制,防止流量洪峰;对单账户控制,防止热点账户影响校验中心:完成交易的完整性校验、幂等性校验、账户状态的可用性校验等决策中心:完成交易和记账规则、结算规则的匹配,同时处理熔断机制下的业务降级决策二、账务清结算业务处理,账务结算的核心处理模块。这部分业务是根据传统的结算业务规则、账务会计规则,通过技术手段实现自动化结算业务、记账业务和会计报表业务。4 技术难点4.1 热点账户即正常交易过程的某个特定时间段内,出现频次特高的账户。若数据库异常重试或交易故障的人工恢复等处理导致的高频,一般不作热点账户。账务处理避免不了数据库行锁。若一次账务处理数据库事务 10ms,对热点账户处理 TPS 最大 100,一旦超过阈值,频繁锁竞争会使数据库性能骤降。热点账户分类:4.1.1 入款热点入款热点常用的做法是缓冲入账,将入款交易缓冲,按照一定的处理速度做账务处理,使得账务处理速度低于 tps 的阈值,保证数据库性能稳定;如果在逐笔缓冲处理仍有压力,可以使用汇总缓冲。4.1.2 出款热点出款热点若采用缓冲,可能导致不良结果,一般不采用,通常对出款热点的处置方案:① 数据库驱动层改写由数据库驱动层检测数据库行锁,在规定时间周期内,合并更新,统一返回处理结果,类似汇总入账,降低热点的更新频度② 数据库水平拆分账务系统的账户记录分散到不同机器的不同表。再对有热点的账户逻辑拆分成多个账户,使拆分的多个账户分散到不同机器的不同表。热点账户变成多个账户,降低账户热度③ 应用层实现通过分布式缓存,冻结部分商户资金放在分布式缓存中,由缓存实时扣款。最终再同步到账户余额。本文账务清结算系统采用分布式缓存方案,包括:账户余额实时处理模块、账户余额缓存处理模块和定时补偿处理模块。4.2 业务处理模块4.2.0 流程图4.2.1 账户余额实时处理接受客户端出款请求,转发到账户余额缓存处理模块处理做实际的数据库余额操作,接受缓存处理模块或定时检查模块请求汇总更新数据库4.2.2 账户余额缓存处理负责用户出款请求。申请缓存余额、余额缓存出款、汇总更新余额功能。4.2.3 定时补偿处理为防止缓存异常等问题导致用户余额失真,定时处理模块定期检查缓存申请的余额处理情况和缓存状态,在缓存过期时调用余额实时处理模块刷新用户余额。5 数据库拆分账务清结算数据按用途分:每笔交易记录借贷双方,便于日终余额核对,同时满足会计上凭证需求需满足交易的日统计需求商户结算账单查询需求,商户 T+1 日需要核对 T 日结算账单数据需满足商户按日实时查询需求小微商户结算周期多变、对账周期长需满足小微商户按月账单读取,甚至按季度账单读取基于热点账户和主要需求,数据库表拆分规则:先按客户属性完成拆分:资金渠道方的数据,需满足按日汇总和 T-2 日对账需求,这部分数据采用按日一级拆分,为避免一日内交易过的,按订单 hash 拆分到不同表中,尽量保证单表的记录在几百万内商户数据,由于支付商户分小微普惠型商户和 KA 商户。这两类商户诉求不尽相同KA 商户资金流大,交易笔数多,要求日清日结,按商户+日期+订单号拆分,控制单笔记录几百万内,保证单日商户数据查询效率小微商户,交易量小,查询时间跨度长,只按商户号一级拆分6 结算规则针对商户计费结算规则多变,设计个标准的算法指令,指令可完成数值比较、四则运算、数据赋值等操作。还设计一套算法组合标准,把若干算法按标准组装成算法执行策略,通过对算法策略包含的每个算法指令的执行,完成计费结算逻辑。6.1 执行流程图关注我,紧跟本系列专栏文章,咱们下篇再续!作者简介:魔都国企技术专家兼架构,多家大厂后端一线研发经验,各大技术社区头部专家博主,编程严选网创始人。具有丰富的引领团队经验,深厚业务架构和解决方案的积累。参考:编程严选网
点赞 0
评论 1
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
01-26 11:41
湖南软件职业学院 前端工程师
简历头像证件照,让你立马拥有商务般的形象照
#Prompt分享#Prompt:简历证件照优化器工具: 千问(对国产的,都不用费劲翻墙,国产也很厉害)提示词正文:能否给我一张专业的头像照片,要求着装为蓝色西装外套搭配白色衬衫,带有淡蓝色的领带,且要双臂交叉, 正面朝向,这张照片我将用于 LinkedIn 的个人资料图片中。效果如下:立马变为
点赞
评论
收藏
分享
01-21 14:59
资产管理
工作后读研是犯了天条吗
20年金融毕业,在深圳某公司做企业文化,工作2年多后;23年读研,实习是产品运营类工作,主要做增长。现在找工作感觉逼到绝境。。。好像路走错了,完全找不到工作,按实习岗位找,体感太少,对运营类工作整体性、系统性掌握不够,找不到好工作;按社招企业文化找,岗位低不成高不就,1-3年内工资少,且中间有gap,3-5年门槛太高,与我自身经历不匹配。兄弟们,接下来应该怎么走啊,没招了。本来读研是为了往运营方向找,目前实习比较少,学的是学硕,被论文耽误不少时间,导致运营类不好找,啊啊啊啊啊啊啊啊啊(本人属于工作强体感类人,需要很强的工作体验才能够从具体中抽离很干货的经验,所以目前面试的互联网运营肉眼可见的不...
点赞
评论
收藏
分享
2025-12-23 23:49
门头沟学院 前端工程师
原来前端已死是这个意思
双非前端已死 投一大圈一个面试约不到 我真心碎了 前端已死
程序员花海:
实习写的太偏项目了
点赞
评论
收藏
分享
01-23 11:09
南昌大学 算法工程师
HH 的项链
链接 恕我无能,这题不看提示真写不来啊~~~ 这题还是要用树状数组,(感觉线段树也行?没试过) 不过得稍微变实现的形式,我们把每个数据都看做1就行了,毕竟每个数据的种类只有1个嘛 但是,问题就在重复上,如果出现重复,那其中一个就必须为0才行,不然求和会不对 比如 1 2 3 4 5我们就转换为1 1 1 1 1 ,然后放进树状数组 但是1 2 3 4 2就不一样了,可能是1 0 1 1 1或是1 1 1 1 0,这两者放进树状数组得到的结果有什么区别呢 由于我们习惯性地从左向右遍历,我们发现,前者当查询区间为[left,5]时,用树状数组查询是正确的,后者则不行(除非从右往左) 因此,我们可以...
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
牛客吐槽大会 | 有槽不吐,留着过年?吐完领现金红包,痛快!
2296
2
...
J人永远闲不下来于是去提前实习
2059
3
...
拥抱AI,程序员的最后出路
1753
4
...
真正会被取代的,是你心里面的幻觉
1646
5
...
mentor视角下的优秀实习生
1592
6
...
马斯克最新炸裂采访,AI会带走一半工作岗位,普通人将何去何从?
1455
7
...
努力挣钱的意义具象化了
1383
8
...
大厂提前实习对AI开发的新感悟
1349
9
...
去独角兽做龙头还是去大厂做凤尾
1187
10
...
我身材再曼妙,也没有我的工资好笑!
1162
创作者周榜
更多
正在热议
更多
#
牛客吐槽大会
#
2038次浏览
54人参与
#
机械人你知道哪些单休企业
#
82960次浏览
413人参与
#
今年春招是金一银二嘛?
#
7280次浏览
80人参与
#
没关系,至少我的__很曼妙
#
3527次浏览
62人参与
#
1月小结:你过的开心吗?
#
1638次浏览
50人参与
#
赚钱的意义在这一刻具象化
#
3686次浏览
90人参与
#
抛开难度不谈,你最想去哪家公司?
#
3649次浏览
92人参与
#
AI时代的工作 VS 传统时代的工作,有哪些不同?
#
7708次浏览
185人参与
#
为什么有人零实习也能进大厂?
#
4569次浏览
104人参与
#
你的第一家实习公司是什么档次?
#
3835次浏览
67人参与
#
你的landing期是如何度过的?
#
7875次浏览
145人参与
#
当你问AI“你会取代我的工作吗”,它说_?
#
3356次浏览
120人参与
#
参加完秋招的机械人,还参加春招吗?
#
103442次浏览
682人参与
#
机械人春招想让哪家公司来捞你?
#
379104次浏览
3139人参与
#
除了Java,最推荐学什么技术?
#
5333次浏览
136人参与
#
AI求职实录
#
2785次浏览
82人参与
#
一人一道大厂面试题
#
114064次浏览
1263人参与
#
设计人如何选offer
#
187054次浏览
864人参与
#
你在职场上见过哪些“水货”同事
#
30689次浏览
167人参与
#
简历中的项目经历要怎么写?
#
287714次浏览
3801人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务