[发明专利]一种缓存处理方法及系统有效
申请号: | 201911369179.7 | 申请日: | 2019-12-26 |
公开(公告)号: | CN111177197B | 公开(公告)日: | 2023-03-14 |
发明(设计)人: | 许高明;朱滨;张英男;兰博 | 申请(专利权)人: | 北京仁科互动网络技术有限公司 |
主分类号: | G06F16/2455 | 分类号: | G06F16/2455;G06F16/23 |
代理公司: | 北京路浩知识产权代理有限公司 11002 | 代理人: | 陈玉婷 |
地址: | 100020 北京市朝*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 缓存 处理 方法 系统 | ||
本发明实施例提供一种缓存处理方法及系统,该方法包括:根据目标数据请求指令,若判断获知目标数据缓存未命中,生成第一目标租约;将所述第一目标租约发送给客户端,以使得所述客户端生成第二目标租约;接收所述第二目标租约,若所述第一目标租约不存在或所述第一目标租约与所述第二目标租约不一致,则不设置缓存。本发明实施例提供的一种缓存处理方法及系统,通过在缓存处理过程中匹配第一目标租约和第二目标租约,如果二者不一致,说明在缓存缺失到读取数据再设置到缓存期间,目标数据发生了修改,因此不设置缓存,这样就避免了缓存和数据库不一致的缺陷。
技术领域
本发明涉及计算机技术领域,尤其涉及一种缓存处理方法及系统。
背景技术
在软件服务中,通常使用数据库作为核心存储。但是数据库的读取速度较慢,为了提高用户查询的速度,往往都会结合缓存使用。引入了缓存后,就可能出现缓存中的数据和数据库中的数据不一致的情况。
根据缓存使用场景的不同,缓存不一致会导致或轻或重的后果,必须加以控制或解决。
发明内容
为了解决上述问题,本发明实施例提供一种缓存处理方法及系统。
第一方面,本发明实施例提供一种缓存处理方法,包括:
根据目标数据请求指令,若判断获知目标数据缓存未命中,生成第一目标租约;
将所述第一目标租约发送给客户端,以使得所述客户端生成第二目标租约;
接收所述第二目标租约,若所述第一目标租约不存在或所述第一目标租约与所述第二目标租约不一致,则不设置缓存。
优选地,还包括:
若所述第一目标租约与所述第二目标租约一致,接收所述目标数据,并将所述目标数据设置缓存,并清除所述第一目标租约,所述目标数据由所述客户端从数据库中获得。
优选地,还包括:
将所述第一目标租约的类型设置为缓存缺失型,若设置缓存的时间超过第一预设时间,则忽略所有设置缓存操作。
优选地,还包括:
若接收到清除指令,则清除缓存,并将所述第一目标租约的类型设置为缓存失效型,若所述第一目标租约的类型为缓存失效型,则忽略所有设置缓存操作。
优选地,还包括:
在对所述数据库进行更新之前,进行缓存失效操作;
并且在第二预设时间内,忽略所有设置缓存操作。
优选地,所述第一目标租约包括实体租约和对象租约,所述实体租约对应实体,所述对象租约对应对象,具体地:
在将实体设置到缓存情况下,若所述实体租约的类型为缓存失效型,将所述实体下的每一对象均设置到缓存中;
在处理缓存情况下,若所述实体租约存在,则判断所述第一目标租约存在;若所述实体租约不存在,且所述对象租约存在,则判断所述第一目标租约存在;若所述实体租约和所述对象租约均不存在,则判断所述第一目标租约不存在。
第二方面,本发明实施例提供一种缓存处理方法,包括:
发送目标数据请求指令,以使得服务器若判断获知目标数据未命中,生成第一目标租约,并发送所述第一目标租约;
根据所述第一目标租约,生成第二目标租约;
将所述第二目标租约发送给所述服务器,所述服务器若判断获知所述第一目标租约不存在或所述第一目标租约与所述第二目标租约不一致,忽略缓存设置请求。
第三方面,本发明实施例提供一种缓存处理系统,包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京仁科互动网络技术有限公司,未经北京仁科互动网络技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201911369179.7/2.html,转载请声明来源钻瓜专利网。