[发明专利]一种分布式数据库系统及其单调读的实现方法、装置有效
申请号: | 202211081162.3 | 申请日: | 2022-09-05 |
公开(公告)号: | CN115145942B | 公开(公告)日: | 2023-01-17 |
发明(设计)人: | 王万红;韩富晟;高山岩;肖金亮 | 申请(专利权)人: | 北京奥星贝斯科技有限公司 |
主分类号: | G06F16/23 | 分类号: | G06F16/23;G06F16/27 |
代理公司: | 北京博思佳知识产权代理有限公司 11415 | 代理人: | 李威 |
地址: | 100020 北京市朝阳区东三*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 分布式 数据库 系统 及其 单调 实现 方法 装置 | ||
1.一种分布式数据库系统,包括版本服务节点和普通节点,所述版本服务节点和所述普通节点分别维护有同一数据对应的副本,其中:
所述版本服务节点用于按照预设周期为所述数据生成单调递增的版本号和所述版本号的完整有效时长,所述完整有效时长不大于所述预设周期的周期时长;
所述普通节点用于:
在任一周期向所述版本服务节点发送版本号获取请求,以获取所述任一周期内生成的目标版本号和所述目标版本号的剩余有效时长,所述剩余有效时长为所述目标版本号的完整有效时长与该目标版本号在所述版本服务节点上的已生效时长之差;以及,
根据所述目标版本号的剩余有效时长,确定所述目标版本号在所述普通节点上的失效时刻,且在确定的失效时刻之前基于所述目标版本号对应的数据响应访问方针对所述数据发起的读请求;其中,所述目标版本号在所述普通节点上的失效时刻不晚于在所述版本服务节点上的失效时刻。
2.根据权利要求1所述的系统,所述普通节点在本地关联缓存获取的所有版本号和以及各个版本号在所述普通节点上对应的失效时刻;所述普通节点还用于:
接收到访问方针对所述数据发起的读请求后,查询本地缓存的版本号及其在所述普通节点上对应的失效时刻;
若本地缓存的任一版本号在所述普通节点上对应的失效时刻尚未到达,则基于所述任一版本号响应接收到的读请求;
若本地缓存的所有版本号在所述普通节点上对应的失效时刻均已到达,则向所述版本服务节点临时请求新的版本号,以用于响应接收到的读请求。
3.根据权利要求1所述的系统,所述普通节点根据所述目标版本号的剩余有效时长,确定所述目标版本号在所述普通节点上的失效时刻,包括:
在所述版本号获取请求的发送时刻的基础上,增加所述目标版本号的剩余有效时长,并将得到的时刻确定为所述目标版本号在所述普通节点上的失效时刻。
4.根据权利要求1所述的系统,所述版本服务节点用于通过下述方式生成当前周期的版本号:
在上一周期发生数据变更的情况下,所述版本服务节点将最近一次发生数据变更时对应的版本号作为当前周期生成的版本号;或,
在上一周期未发生数据变更的情况下,所述版本服务节点将上一周期生成的版本号作为当前周期生成的版本号。
5.根据权利要求1所述的系统,在所述版本服务节点由所述分布式数据库系统中的第一节点变更为第二节点的情况下,所述第二节点用于:
在所述第一节点生成的所有版本号均已失效后,接替所述第一节点按照所述预设周期为所述数据生成单调递增的版本号和所述版本号的完整有效时长。
6.根据权利要求5所述的系统,所述第二节点通过下述任一方式确定所述第一节点生成的所有版本号均已失效:
所述第二节点在等待至少一个预设周期的周期时长后,确定所述第一节点生成的所有版本号均已失效;或,
在所述第一节点在当前周期内生成的最新版本号尚未过期的情况下,在所述第二节点针对所述最新版本号的接收时刻的基础上增加所述最新版本号对应的剩余有效时长,并将得到的时刻确定为所述第一节点生成的所有版本号的失效时刻。
7.一种基于分布式数据库系统的单调读的实现方法,所述分布式数据库系统包括版本服务节点和普通节点,所述版本服务节点和普通节点分别维护有同一数据对应的副本,应用于所述版本服务节点,所述方法包括:
按照预设周期为所述数据生成单调递增的版本号和所述版本号的完整有效时长,所述完整有效时长不大于所述预设周期的周期时长;
响应于所述普通节点在任一周期内发送的版本号获取请求,向所述普通节点发送所述任一周期内生成的目标版本号和所述目标版本号的剩余有效时长,以使所述普通节点根据所述目标版本号的剩余有效时长,确定所述目标版本号在所述普通节点上的失效时刻,且在确定的失效时刻之前基于所述目标版本号对应的数据响应访问方针对所述数据发起的读请求;其中,所述目标版本号在所述普通节点上的失效时刻不晚于在所述版本服务节点上的失效时刻,所述剩余有效时长为所述目标版本号的完整有效时长与该目标版本号在所述版本服务节点上的已生效时长之差。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京奥星贝斯科技有限公司,未经北京奥星贝斯科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202211081162.3/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种桥架支架零部件的激光焊接设备
- 下一篇:基于改进的链码法的棉花顶检测方法