[发明专利]基于缓存的并发能力提升方法、装置、设备及存储介质在审
申请号: | 202110150945.1 | 申请日: | 2021-02-03 |
公开(公告)号: | CN112860794A | 公开(公告)日: | 2021-05-28 |
发明(设计)人: | 唐小龙 | 申请(专利权)人: | 百果园技术(新加坡)有限公司 |
主分类号: | G06F16/27 | 分类号: | G06F16/27;G06F16/23;G06F16/21 |
代理公司: | 北京泽方誉航专利代理事务所(普通合伙) 11884 | 代理人: | 陈照辉 |
地址: | 巴西班让路枫树*** | 国省代码: | 暂无信息 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 基于 缓存 并发 能力 提升 方法 装置 设备 存储 介质 | ||
本申请实施例公开了基于缓存的并发能力提升方法、装置、设备及存储介质。本申请实施例提供的技术方案通过将从数据层中加载的内存版本数据作为只读版本数据缓存在逻辑层中,同时将只读版本数据在逻辑层中缓存为业务版本数据,在一个或多个数据处理请求到来时,在逻辑层中对业务版本数据进行业务处理,并将进行业务处理后的业务版本数据拷贝并缓存为待同步版本数据,在成功将待同步版本数据写回数据层时,向请求者返回相应的请求处理结果,实现对高并发请求的低延时响应,并保证了返回结果与数据层数据的一致性,同时有效提升对高并发请求的承载能力。
技术领域
本申请实施例涉及计算机技术领域,尤其涉及基于缓存的并发能力提升方法、装置、设备及存储介质。
背景技术
在部分互联网业务场景中,存在某些数据同时被大量用户访问与修改的情况,例如在直播连麦服务中的抢麦场景、电商服务中商品秒杀场景。一般情况下,会针对这些业务场景做数据层与逻辑层的服务分离,在请求到来时会从数据层加载数据到逻辑层,在逻辑层中根据请求对数据进行处理后,再将数据写回数据层,最后才向请求者返回处理结果。
上述处理方式在每个请求来到时,都会进行数据的加载、处理与写回,因此一个请求的处理时间会高于逻辑层与数据层的数据传输时延,而下一个请求必须在前一个请求处理完毕才可以继续处理,这时候高并发量的请求与数据读写延时之间的矛盾就会显现出来,导致对高并发请求的处理能力受限。
发明内容
本申请实施例提供基于缓存的并发能力提升方法、装置、设备及存储介质,以提升对高并发请求的处理能力。
在第一方面,本申请实施例提供了一种基于缓存的并发能力提升方法,包括:
从数据层加载内存版本数据,并将所述内存版本数据作为只读版本数据缓存在逻辑层中;
将所述只读版本数据拷贝为业务版本数据,并将所述业务版本数据缓存在所述逻辑层中,同时依据请求者发出的一个或多个数据处理请求,对所述业务版本数据进行业务处理;
将进行业务处理后的所述业务版本数据拷贝为待同步版本数据,并将所述待同步版本数据缓存在所述逻辑层中;
依据所述待同步版本数据对所述数据层进行数据写回操作,并基于数据写回操作结果,向所述请求者返回相应的请求处理结果。
在第二方面,本申请实施例提供了一种基于缓存的并发能力提升装置,包括数据加载模块、数据处理模块、数据同步模块和数据写回模块,其中:
所述数据加载模块,用于从数据层加载内存版本数据,并将所述内存版本数据作为只读版本数据缓存在逻辑层中;
所述数据处理模块,用于将所述只读版本数据拷贝为业务版本数据,并将所述业务版本数据缓存在所述逻辑层中,同时依据请求者发出的一个或多个数据处理请求,对所述业务版本数据进行业务处理;
所述数据同步模块,用于将进行业务处理后的所述业务版本数据拷贝为待同步版本数据,并将所述待同步版本数据缓存在所述逻辑层中;
所述数据写回模块,用于依据所述待同步版本数据对所述数据层进行数据写回操作,并基于数据写回操作结果,向所述请求者返回相应的请求处理结果。
在第三方面,本申请实施例提供了一种基于缓存的并发能力提升设备,包括:存储器以及一个或多个处理器;
所述存储器,用于存储一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如第一方面所述的基于缓存的并发能力提升方法。
在第四方面,本申请实施例提供了一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行如第一方面所述的基于缓存的并发能力提升方法。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于百果园技术(新加坡)有限公司,未经百果园技术(新加坡)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110150945.1/2.html,转载请声明来源钻瓜专利网。