The invention discloses a highly available billing system and billing generation processing method. The method includes: billing real-time generation: invoking API real-time generating bills in BillGenSDK before batch generating bills, pushing bills to generate messages to message queues immediately, caching immediate generated bills in the Redis database; billing batches. Volume generation: the API batch generation bill in BillGenSDK is generated and stored in the Mysql database; and the bills that have been cached in the Redis database are persisted to the MySQL database through the consumption message. The invention reduces the strong dependence on the bill generation module and improves the availability of the bill display; at the same time, it realizes the cache and persistence of the immediate generation of bills, avoids the repeated generation of bills, improves the generation efficiency, reduces the response time of the query, ensures the normal presentation of the bill, improves the availability of the bill system, and improves the user experience.
【技术实现步骤摘要】
一种高可用的账单系统及账单生成处理方法
本专利技术涉及金融交易控制领域,具体涉及一种高可用的账单系统及账单生成处理方法。
技术介绍
目前账单系统的主要功能在于用户账单的展示,通常高度依赖于用户交易汇总数据,现有的解决方案是:定时任务模块通过定时任务在用户的账单日定时生成月账单和个人账单,并持久化到mySQL数据库,账单系统再以用户和账单年月等维度进行查询,这种解决方案的实现方式比较直观、简单,账单生成系统和交易系统以及账单系统的耦合度较低。但是,随着用户数量的快速增长,账单的生成时间会不断增加,将会导致出账所需时间不断延长,同时,异常账单和交易的发生几率也会增加,在用户生成账单的过程中,如果发生还款、退款等交易行为,则需要进行特殊处理;当用户进行查询操作时,账单系统的当月账单查询功能也会处于长时间的不可用状态,可用性较差,严重影响到用户体验。
技术实现思路
本专利技术所要解决的技术问题是现有的账单系统发生异常账单和交易的几率较高,可用性较差,严重影响到用户体验的问题。为了解决上述技术问题,本专利技术所采用的技术方案是提供一种高可用的账单系统,包括:账单即时生成模块,在批量生成账单之前,调用BillGenSDK中的API即时生成账单,并进行消息推送和缓存;Redis数据库,存储所述账单即时生成模块即时生成的账单和已经持久化的账单;消息推送模块,推送账单即时生成消息到消息队列;缓存账单获取模块,根据接收到的所述消息推送模块推送的账单即时生成消息,获取所述Redis数据库中的缓存账单并持久化;账单批量生成模块,通过任务的方式,调用BillGenSDK中的API批量生 ...
【技术保护点】
1.一种高可用的账单系统,其特征在于,包括:账单即时生成模块,在批量生成账单之前,调用BillGenSDK中的API即时生成账单,并进行消息推送和缓存;Redis数据库,存储所述账单即时生成模块即时生成的账单和已经持久化的账单;消息推送模块,推送账单即时生成消息到消息队列;缓存账单获取模块,根据接收到的所述消息推送模块推送的账单即时生成消息,获取所述Redis数据库中的缓存账单并持久化;账单批量生成模块,通过任务的方式,调用BillGenSDK中的API批量生成账单,并存储到Mysql数据库中;同时,对于已经缓存在Redis数据库中的即时生成的账单,通过消费消息的方式,持久化存储到MySQL数据库中。
【技术特征摘要】
1.一种高可用的账单系统,其特征在于,包括:账单即时生成模块,在批量生成账单之前,调用BillGenSDK中的API即时生成账单,并进行消息推送和缓存;Redis数据库,存储所述账单即时生成模块即时生成的账单和已经持久化的账单;消息推送模块,推送账单即时生成消息到消息队列;缓存账单获取模块,根据接收到的所述消息推送模块推送的账单即时生成消息,获取所述Redis数据库中的缓存账单并持久化;账单批量生成模块,通过任务的方式,调用BillGenSDK中的API批量生成账单,并存储到Mysql数据库中;同时,对于已经缓存在Redis数据库中的即时生成的账单,通过消费消息的方式,持久化存储到MySQL数据库中。2.如权利要求1所述的高可用的账单系统,其特征在于,还包括MySQL数据库,存储所述账单即时生成模块即时生成的账单和所述账单生成模块已经持久化的账单。3.一种高可用的账单生成处理方法,其特征在于,包括以下步骤:账单即时生成:在批量生成账单之前,调用Bi...
【专利技术属性】
技术研发人员:彭雨,姚艳豪,孔之源,
申请(专利权)人:广州品唯软件有限公司,
类型:发明
国别省市:广东,44
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。