[发明专利]用于版本管理系统的数据同步方法及设备有效
申请号: | 201710197728.1 | 申请日: | 2017-03-29 |
公开(公告)号: | CN107451172B | 公开(公告)日: | 2021-05-28 |
发明(设计)人: | 张跃;李闪;武萌 | 申请(专利权)人: | 阿里巴巴集团控股有限公司 |
主分类号: | G06F16/18 | 分类号: | G06F16/18;G06F16/11;H04L12/24;H04L29/08 |
代理公司: | 上海百一领御专利代理事务所(普通合伙) 31243 | 代理人: | 陈贞健;邵栋 |
地址: | 英属开曼群岛大开*** | 国省代码: | 暂无信息 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 用于 版本 管理 系统 数据 同步 方法 设备 | ||
本申请的一个目的是提供一种用于版本管理系统的数据同步方法及设备。具体地,主节点设备在接收到写操作请求时,根据写操作请求更新主节点设备对应的版本管理系统的数据内容,并向存储设备写入写操作请求对应的操作记录,以及向存储设备中写入存储点;从节点设备在启动时,从存储设备读取存储点,根据记录指针从存储设备读取后续操作记录,根据当前数据内容及后续操作记录更新从节点设备对应的版本管理系统的数据内容。与现有技术相比,采用的是实时的增量数据备份,减少了数据的存储量,并且不需要对已有版本管理系统进行改造,可以适用于各类系统,并不会增加数据处理的复杂性,因此不会降低系统性能。
技术领域
本申请涉及计算机领域,尤其涉及一种用于版本管理系统的数据同步方法及设备。
背景技术
版本管理系统可以存储、追踪目录和文件的修改历史,用于存储软件开发的代码,文档等内容。当前流行的版本管理系统有csv,svn,git等。根据工作方式又可以进一步分为集中式和分布式管理系统两种。集中式版本管理依赖于一个全局的存储仓库,对数据的同步和管理更加方便,但是也造成了可用性的限制。分布式版本管理系统在本地复制一份全局的数据后,就可以不依赖全局存储,只要在必要的时候去和全局进行同步,提高了系统的工作效率。
目前,分布式版本管理系统的数据同步方式主要有以下两种方案:
1、通过定期的全量备份版本管理系统中的所有存储数据,当部署版本管理系统的节点设备发生故障后,用最近的一次备份进行恢复。但是由于定期的备份实时性差,当发生故障时服务会发生中断,没有来得及备份的数据也会发生丢失,而且每次进行全量备份也会导致存储量较大。
2、通过对特定版本管理系统进行改造,将对外服务的入口由单节点入口扩展为多节点,并通过一个调度器进行负载调度,当有一个节点设备故障时,其他节点可以继续服务。但是,对特定版本管理系统的改造(如git),不能应用到其他版本管理系统中(如svn,cvs等),并且由于将单节点入口扩展为多单节点入口,增加了系统的复杂性,对于每次请求的处理需要消耗更多的资源,影响性能。
本申请的一个目的是提供一种用于版本管理系统的数据同步方法及设备,用以解决现有技术中同步数据的存储量大、处理复杂性高的问题。
为实现上述目的,本申请提供了一种在主节点设备端用于版本管理系统的数据同步方法,该方法包括:
在接收到写操作请求时,根据所述写操作请求更新所述主节点设备对应的版本管理系统的数据内容,并向存储设备写入所述写操作请求对应的操作记录;
向所述存储设备中写入存储点,其中,所述存储点包括写入存储点时所述版本管理系统的当前数据内容,以及指向该当前数据内容的下一条操作记录的记录指针。
本申请还提供了一种在从节点设备端用于版本管理系统的数据同步方法,该方法包括:
在启动时,从存储设备读取存储点,其中所述存储点包括主节点设备对应的版本管理系统在写入所述存储点时的当前数据内容,以及指向该当前数据内容的下一条操作记录的记录指针;
根据所述记录指针从所述存储设备读取后续操作记录;
根据所述当前数据内容及所述后续操作记录更新所述从节点设备对应的版本管理系统的数据内容。
基于本申请的另一方面,还提供了一种用于版本管理系统数据同步的主节点设备,该设备包括:
数据处理装置,用于在接收到写操作请求时,根据所述写操作请求更新所述主节点设备对应的版本管理系统的数据内容;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于阿里巴巴集团控股有限公司,未经阿里巴巴集团控股有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201710197728.1/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种商品自助推送方法及系统
- 下一篇:一种基于舱门细节模型的强度校核方法