首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
JavaEdge
华为_2012实验室_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
Java求职圈
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
07-16 10:58
西安科技大学 golang
虾皮26秋招提前批来了~
虾皮已开,但是每人只可投递一个 提前批与正式批应该不影响 虽然是"研发提前批"但有产品 数分 职能岗
投递虾皮信息等公司8个岗位
点赞
评论
收藏
分享
07-14 23:30
门头沟学院 测试开发
三段实习仍然迷茫
bg:26普本,三段实习(互联网小厂+硬件大厂+游戏大厂测开)未来打算走业务测试的路线,编码能力比较差,不太喜欢做很多代码工作,现在写个一千行左右的代码都难交付;比较擅长包装扯皮(嘴皮子比较溜),现在来到的游戏大厂也是当时包装混进来的因为学历比较差加上实习经历和互联网不太垂直,现在比较纠结要不要跑路找个互联网中大厂日常测开,边实习边秋招,最近投了投感觉现在的游戏业务,投互联网还是有些吃亏?大佬们有见过游测顺利转互联网的吗,据说不好转,未来也不打算一直搞游戏,所以想跳出去ps:很纠结的是,我这个组贼养老,平常背八股刷力扣随便请假啥的组长不管,平常一个月需求,认真搞十天就能ok,其实是个苟住的不错...
投递腾讯等公司8个岗位
点赞
评论
收藏
分享
06-26 21:09
长沙理工大学 C++
有没有人来制裁一下
如下图,真让我惊到了,有没有人去给这老板上一课
写不来代码的小黑:
这么小的城市能有做it的公司也不容易
点赞
评论
收藏
分享
05-23 21:27
成都信息工程大学 网络安全
避坑
避坑恶心到我了大家好,今天我想跟大家聊聊我在成都千子成智能科技有限公司(以下简称千子成)的求职经历,希望能给大家一些参考。千子成的母公司是“同创主悦”,主要经营各种产品,比如菜刀、POS机、电话卡等等。听起来是不是有点像地推销售公司?没错,就是那种类型的公司。我当时刚毕业,急需一份临时工作,所以在BOSS上看到了千子成的招聘信息。他们承诺无责底薪5000元,还包住宿,这吸引了我。面试的时候,HR也说了同样的话,感觉挺靠谱的。于是,我满怀期待地等待结果。结果出来后,我通过了面试,第二天就收到了试岗通知。试岗的内容就是地推销售,公司划定一个区域,然后你就得见人就问,问店铺、问路人,一直问到他们有意向为止。如果他们有兴趣,你就得摇同事帮忙推动,促进成交。说说一天的工作安排吧。工作时间是从早上8:30到晚上18:30。早上7点有人叫你起床,收拾后去公司,然后唱歌跳舞(销售公司都这样),7:55早课(类似宣誓),8:05同事间联系销售话术,8:15分享销售技巧,8:30经理训话。9:20左右从公司下市场,公交、地铁、自行车自费。到了市场大概10点左右,开始地推工作。中午吃饭时间大约是12:00,公司附近的路边盖饭面馆店自费AA,吃饭时间大约40分钟左右。吃完饭后继续地推工作,没有所谓的固定中午午休时间。下午6点下班后返回公司,不能直接下班,需要与同事交流话术,经理讲话洗脑。正常情况下9点下班。整个上班的一天中,早上到公司就是站着的,到晚上下班前都是站着。每天步数2万步以上。公司员工没有自己的工位,百来号人挤在一个20平方米的空间里听经理洗脑。白天就在市场上奔波,公司的投入成本几乎只有租金和工资,没有中央空调。早上2小时,晚上加班2小时,纯蒸桑拿。没有任何福利,节假日也没有3倍工资之类的。偶尔会有冲的酸梅汤和西瓜什么的。公司的晋升路径也很有意思:新人—组长—领队—主管—副经理—经理。要求是业绩和团队人数,类似传销模式,把人留下来。新人不能加微信、不能吐槽公司、不能有负面情绪、不能谈恋爱、不能说累。在公司没有任何坐的地方,不能依墙而坐。早上吃早饭在公司外面的安全通道,未到上班时间还会让你吃快些不能磨蹭。总之就是想榨干你。复试的时候,带你的师傅会给你营造一个钱多事少离家近的工作氛围,吹嘘工资有多高、还能吹自己毕业于好大学。然后让你早点来公司、无偿加班、抓住你可能不会走的心思进一步压榨你。总之,大家在找工作的时候一定要擦亮眼睛,避免踩坑!———来自网友
qq乃乃好喝到咩噗茶:
不要做没有专业门槛的工作
点赞
评论
收藏
分享
不愿透露姓名的神秘牛友
07-11 11:29
遇到了很没素质的求职者
当hr当的心累了,莫名其妙就会被骂😭
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
1
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
关于项目烂大街的那些事
8926
2
...
0实习0面试, 速通拼多多
7161
3
...
秋招公司情报局,分享线索得牛币💰
6867
4
...
秋招腾讯TEG提前批(三面挂)
6573
5
...
后端实习到底该干什么啊
4820
6
...
从外包到正式工,从Java开发到私有云运维:我的职场逆袭之路
4476
7
...
明天五场面试,加油
3213
8
...
王侯将相宁有种乎!
2855
9
...
我和妈妈讲以后我可能给不了她一个月1500
2718
10
...
双非本应届是如何拿到30
2600
创作者周榜
更多
正在热议
更多
#
26届的你们有几段实习?
#
19526次浏览
273人参与
#
你小时候最想从事什么职业
#
102703次浏览
1771人参与
#
你被哪些公司秒挂过?
#
18590次浏览
182人参与
#
网申一定要掌握的小技巧
#
9641次浏览
65人参与
#
如何提高实习转正率?
#
7528次浏览
133人参与
#
新凯来求职进展汇总
#
41015次浏览
108人参与
#
你认为哪些项目算烂大街?
#
8261次浏览
196人参与
#
机械校招之路总结
#
92413次浏览
1889人参与
#
你后悔自己读研吗?
#
8909次浏览
175人参与
#
你以为的实习VS真实的实习
#
11439次浏览
131人参与
#
月薪多少能在一线城市生存
#
10682次浏览
169人参与
#
腾讯工作体验
#
479913次浏览
3498人参与
#
找工作时的取与舍
#
81316次浏览
577人参与
#
最难的技术面是哪家公司?
#
5924次浏览
57人参与
#
秋招拿一个offer可以躺平吗
#
144943次浏览
928人参与
#
安利/避雷我的专业
#
77737次浏览
526人参与
#
面试等了一周没回复,还有戏吗
#
137175次浏览
1229人参与
#
你想留在一线还是回老家?
#
50029次浏览
513人参与
#
选择和努力,哪个更重要?
#
86054次浏览
745人参与
#
当下环境,你会继续卷互联网,还是看其他行业机会
#
114933次浏览
799人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务