一种基于DevOps的制品同步方法、设备转让专利

申请号 : CN202111077370.1

文献号 : CN113542433B

文献日 :

基本信息:

PDF:

法律信息:

相似专利:

发明人 : 张坚欣陈灿邹方勇

申请人 : 广州嘉为科技有限公司

摘要 :

本申请公开了一种基于DevOps的制品同步方法、设备,该方法包括:创建多个节点,多个节点中的部分节点用于同步分发任一制品;获取用户的第一操作信息,并基于第一操作信息,确定待分发的任一第一制品对应的至少一个目标节点;多个节点包括至少一个目标节点;获取待执行的同步计划,同步计划为用于同步分发任一第一制品时的计划;执行同步计划,将任一第一制品同步分发到至少一个目标节点,获得任一第一制品对应的第一同步结果;输出第一同步结果。通过这种方式,可以实现任一制品的自动同步分发,可以解决网络分区和带宽限制等一系列问题,可以解放用户的双手,可以实现高效的制品同步分发,从而可以提高软件产品的生产力。

权利要求 :

1.一种基于DevOps的制品同步方法,其特征在于,包括:采用边缘节点模式或独立节点模式创建多个节点,所述多个节点中的部分节点用于同步分发任一制品;其中,当采用所述边缘节点模式创建所述多个节点时,所述多个节点中的任一对主从节点之间共享数据库,并在同步分发制品时把Blob数据分发到所述多个节点中的边缘节点;当采用所述独立节点模式创建所述多个节点时,所述多个节点中的主节点和所述多个节点中的独立节点不共享数据库,并在同步分发制品时把metadata数据和所述B lob数据给所述多个节点中的独立节点创建多个节点;所述多个节点中的任一节点为边缘节点、远程节点、独立节点、中心节点中的一个节点;所述边缘节点和所述独立节点属于从节点,所述中心节点属于主节点;

获取用户的第一操作信息,并基于所述第一操作信息,确定待分发的任一第一制品对应的至少一个目标节点;所述多个节点包括所述至少一个目标节点;

获取待执行的同步计划,所述同步计划为用于同步分发所述任一第一制品时的计划;

执行所述同步计划,将所述任一第一制品同步分发到所述至少一个目标节点,获得所述任一第一制品对应的第一同步结果;

输出所述第一同步结果。

2.如权利要求1所述的方法,其特征在于,获取用户的第一操作信息之前,所述方法还包括:

测试所述多个节点中的远程节点和所述多个节点中的主节点之间的连接是否可用;

当确定所述多个节点中的远程节点和所述多个节点中的主节点之间的连接不可用时,输出提示信息,用于提示所述多个节点中的远程节点和所述多个节点中的主节点之间的连接不可用。

3.如权利要求1所述的方法,其特征在于,所述同步计划包括:同步分发所述任一第一制品时将采用的调度策略、同步策略和执行策略;

执行所述同步计划,将所述任一第一制品同步分发到所述至少一个目标节点,包括:确定所述任一第一制品是否为所述多个节点中的主节点上新增的制品;

若确定所述任一第一制品是所述多个节点中的主节点上新增的制品,则基于所述执行策略,确定执行所述同步策略;基于所述同步策略,将所述任一第一制品同步分发到所述至少一个目标节点;或者,

若确定所述任一第一制品不是所述多个节点中的主节点上新增的制品,则基于所述执行策略,确定执行所述调度策略和所述调度策略;结合所述调度策略和所述同步策略,将所述任一第一制品同步分发到所述至少一个目标节点。

4.如权利要求3所述的方法,其特征在于,所述调度策略包括所述任一第一制品对应的同步方式,所述同步方式包括:立即同步方式、指定时间同步方式和定时同步方式中的一种;所述同步策略包括所述任一第一制品对应的数据同步方式,所述数据同步方式包括:按照仓库同步方式、按照制品同步方式和按照文件同步方式中的一种。

5.如权利要求4所述的方法,其特征在于,基于所述同步策略,将所述任一第一制品同步分发到所述至少一个目标节点,包括:基于所述同步策略,确定所述任一第一制品对应的数据同步方式;

采用所述数据同步方式,将所述任一第一制品同步分发到所述至少一个目标节点;

结合所述调度策略和所述同步策略,将所述任一第一制品同步分发到所述至少一个目标节点,包括:

基于所述调度策略,确定所述任一第一制品对应的数据同步方式;

基于所述同步策略,确定所述任一第一制品对应的数据同步方式;

结合采用所述同步方式和所述数据同步方式,将所述任一第一制品同步分发到所述至少一个目标节点。

6.如权利要求4所述的方法,其特征在于,所述调度策略还包括:冲突处理方式、错误处理方式和执行方式中的一种或多种;

所述冲突处理方式包括:选择跳过、覆盖、快速失败中的一种;

所述错误处理方式包括:选择继续执行、快速失败中的一种;

所述执行方式包括:选择继续执行或快速失败中的一种。

7.如权利要求1‑6任一项所述的方法,其特征在于,所述第一同步结果包括成功数量、失败数量、冲突数量和所述任一第一制品的同步结果;所述成功数量为同步分发成功的第一制品对应的数量;所述失败数量为同步分发失败的第一制品对应的数量;所述冲突数量为同步分发冲突的第一制品对应的数量。

8.一种基于DevOps的制品同步设备,其特征在于,包括:创建单元,用于采用边缘节点模式或独立节点模式创建多个节点,所述多个节点中的部分节点用于同步分发任一制品;其中,当采用所述边缘节点模式创建所述多个节点时,所述多个节点中的任一对主从节点之间共享数据库,并在同步分发制品时把Blob数据分发到所述多个节点中的边缘节点;当采用所述独立节点模式创建所述多个节点时,所述多个节点中的主节点和所述多个节点中的独立节点不共享数据库,并在同步分发制品时把metadata数据和所述B lob数据给所述多个节点中的独立节点创建多个节点;所述多个节点中的任一节点为边缘节点、远程节点、独立节点、中心节点中的一个节点;所述边缘节点和所述独立节点属于从节点,所述中心节点属于主节点;

接收单元,用于获取用户的第一操作信息,并基于所述第一操作信息,确定待分发的任一第一制品对应的至少一个目标节点;所述多个节点包括所述至少一个目标节点;获取待执行的同步计划,所述同步计划为用于同步分发所述任一第一制品时的计划;

处理单元,用于执行所述同步计划,将所述任一第一制品同步分发到所述至少一个目标节点,获得所述至少一个第一制品对应的第一同步结果;

输出单元,用于输出所述第一同步结果。

9.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有至少一个程序;当所述至少一个程序被处理器执行时,实现如权利要求1‑7任一项所述的方法。

说明书 :

一种基于DevOps的制品同步方法、设备

技术领域

[0001] 本申请涉及软件制品同步技术领域,特别是涉及一种基于DevOps的制品同步方法、设备。

背景技术

[0002] 移动互联网时代,软件产品的迭代速度要求越来越高。制品仓库作为DevOps领域不可缺少的一环,扮演着极其重要的作用。但是,由于网络分区的存在,导致制品下载时存
在请求代理超时,网络隔断导致请求中断,高峰时期占用带宽过大等问题。因此,需要将制
品提前存储在本地,以便于使用时可以直接从本地下载,不需要占用其它的网络请求。若要
确保可以将制品存储在本地,则需要制品的分发同步功能。
[0003] 然而,目前制品的分发同步需要通过人工手动的将制品包在一个节点上拉取下来之后,再在另一个节点上传到本地。可见,目前制品的分发同步需要用户频繁的手动操作,
操作较繁琐。

发明内容

[0004] 基于此,本申请提供一种基于DevOps的制品同步方法、设备,用于解决现有技术中存在的制品的分发同步需要用户频繁的手动操作,操作较繁琐的问题,可以解放用户的双
手,可以实现高效的制品同步分发,从而可以提高软件产品的生产力。
[0005] 第一方面,本申请实施例提供一种基于DevOps的制品同步方法,包括:
[0006] 创建多个节点,所述多个节点中的部分节点用于同步分发任一制品;
[0007] 获取用户的第一操作信息,并基于所述第一操作信息,确定待分发的任一第一制品对应的至少一个目标节点;所述多个节点包括所述至少一个目标节点;
[0008] 获取待执行的同步计划,所述同步计划为用于同步分发所述任一第一制品时的计划;
[0009] 执行所述同步计划,将所述任一第一制品同步分发到所述至少一个目标节点,获得所述任一第一制品对应的第一同步结果;
[0010] 输出所述第一同步结果。
[0011] 在一种可能的设计中,所述多个节点中的任一节点为边缘节点、远程节点、独立节点、中心节点中的一个节点;所述边缘节点和所述独立节点属于从节点,所述中心节点属于
主节点;
[0012] 创建多个节点,包括:
[0013] 采用边缘节点模式或独立节点模式创建所述多个节点;其中,
[0014] 当采用所述边缘节点模式创建所述多个节点时,所述多个节点中的任一对主从节点之间共享数据库,并在同步分发制品时把Blob数据分发到所述多个节点中的边缘节点;
[0015] 当采用所述独立节点模式创建所述多个节点时,所述多个节点中的主节点和所述多个节点中的独立节点不共享数据库,并在同步分发制品时把metadata数据和所述blob数
据给所述多个节点中的独立节点。
[0016] 在一种可能的设计中,获取用户的第一操作信息之前,所述方法还包括:
[0017] 测试所述多个节点中的远程节点和所述多个节点中的主节点之间的连接是否可用;
[0018] 当确定所述多个节点中的远程节点和所述多个节点中的主节点之间的连接不可用时,输出提示信息,用于提示所述多个节点中的远程节点和所述多个节点中的主节点之
间的连接不可用。
[0019] 在一种可能的设计中,所述同步计划包括:同步分发所述任一第一制品时将采用的调度策略、同步策略和执行策略;
[0020] 执行所述同步计划,将所述任一第一制品同步分发到所述至少一个目标节点,包括:
[0021] 确定所述任一第一制品是否为所述多个节点中的主节点上新增的制品;
[0022] 若确定所述任一第一制品是所述多个节点中的主节点上新增的制品,则基于所述执行策略,确定执行所述同步策略;基于所述同步策略,将所述任一第一制品同步分发到所
述至少一个目标节点;或者,
[0023] 若确定所述任一第一制品不是所述多个节点中的主节点上新增的制品,则基于所述执行策略,确定执行所述调度策略和所述调度策略;结合所述调度策略和所述同步策略,
将所述任一第一制品同步分发到所述至少一个目标节点。
[0024] 在一种可能的设计中,所述调度策略包括所述任一第一制品对应的同步方式,所述同步方式包括:立即同步方式、指定时间同步方式和定时同步方式中的一种;所述同步策
略包括所述任一第一制品对应的数据同步方式,所述数据同步方式包括:按照仓库同步方
式、按照制品同步方式和按照文件同步方式中的一种。
[0025] 在一种可能的设计中,基于所述同步策略,将所述任一第一制品同步分发到所述至少一个目标节点,包括:
[0026] 基于所述同步策略,确定所述任一第一制品对应的数据同步方式;
[0027] 采用所述数据同步方式,将所述任一第一制品同步分发到所述至少一个目标节点;
[0028] 结合所述调度策略和所述同步策略,将所述任一第一制品同步分发到所述至少一个目标节点,包括:
[0029] 基于所述调度策略,确定所述任一第一制品对应的数据同步方式;
[0030] 基于所述同步策略,确定所述任一第一制品对应的数据同步方式;
[0031] 结合采用所述同步方式和所述数据同步方式,将所述任一第一制品同步分发到所述至少一个目标节点。
[0032] 在一种可能的设计中,所述调度策略还包括:冲突处理方式、错误处理方式和执行方式中的一种或多种;
[0033] 所述冲突处理方式包括:选择跳过、覆盖、快速失败中的一种;
[0034] 所述错误处理方式包括:选择继续执行、快速失败中的一种;
[0035] 所述执行方式包括:选择继续执行或快速失败中的一种。
[0036] 在一种可能的设计中,所述第一同步结果包括成功数量、失败数量、冲突数量和所述任一第一制品的同步结果;所述成功数量为同步分发成功的第一制品对应的数量;所述
失败数量为同步分发失败的第一制品对应的数量;所述成功数量为同步分发冲突的第一制
品对应的数量。
[0037] 第二方面,本申请实施例提供一种基于DevOps的制品同步设备,包括:
[0038] 创建单元,用于创建多个节点,所述多个节点中的部分节点用于同步分发任一制品;
[0039] 接收单元,用于获取用户的第一操作信息,并基于所述第一操作信息,确定待分发的任一第一制品对应的至少一个目标节点;所述多个节点包括所述至少一个目标节点;获
取待执行的同步计划,所述同步计划为用于同步分发所述任一第一制品时的计划;
[0040] 处理单元,用于执行所述同步计划,将所述任一第一制品同步分发到所述至少一个目标节点,获得所述至少一个第一制品对应的第一同步结果;
[0041] 输出单元,用于输出所述第一同步结果。
[0042] 在一种可能的设计中,所述多个节点中的任一节点为边缘节点、远程节点、独立节点、中心节点中的一个节点;所述边缘节点和所述独立节点属于从节点,所述中心节点属于
主节点;所述创建单元具体用于:
[0043] 采用边缘节点模式或独立节点模式创建所述多个节点;其中,
[0044] 当所述创建单元采用所述边缘节点模式创建所述多个节点时,所述多个节点中的任一对主从节点之间共享数据库,并在同步分发制品时把Blob数据分发到所述多个节点中
的边缘节点;
[0045] 当所述创建单元采用所述独立节点模式创建所述多个节点时,所述多个节点中的主节点和所述多个节点中的独立节点不共享数据库,并在同步分发制品时把metadata数据
和所述blob数据给所述多个节点中的独立节点。
[0046] 在一种可能的设计中,获取用户的第一操作信息之前,所述处理单元还用于:测试所述多个节点中的远程节点和所述多个节点中的主节点之间的连接是否可用;
[0047] 所述输出单元还用于:当所述处理单元确定所述多个节点中的远程节点和所述多个节点中的主节点之间的连接不可用时,输出提示信息,用于提示所述多个节点中的远程
节点和所述多个节点中的主节点之间的连接不可用。
[0048] 在一种可能的设计中,所述同步计划包括:同步分发所述任一第一制品时将采用的调度策略、同步策略和执行策略;所述处理单元具体用于:
[0049] 确定所述任一第一制品是否为所述多个节点中的主节点上新增的制品;
[0050] 若确定所述任一第一制品是所述多个节点中的主节点上新增的制品,则基于所述执行策略,确定执行所述同步策略;基于所述同步策略,将所述任一第一制品同步分发到所
述至少一个目标节点;或者,
[0051] 若确定所述任一第一制品不是所述多个节点中的主节点上新增的制品,则基于所述执行策略,确定执行所述调度策略和所述调度策略;结合所述调度策略和所述同步策略,
将所述任一第一制品同步分发到所述至少一个目标节点。
[0052] 在一种可能的设计中,所述调度策略包括所述任一第一制品对应的同步方式,所述同步方式包括:立即同步方式、指定时间同步方式和定时同步方式中的一种;所述同步策
略包括所述任一第一制品对应的数据同步方式,所述数据同步方式包括:按照仓库同步方
式、按照制品同步方式和按照文件同步方式中的一种。
[0053] 在一种可能的设计中,所述处理单元具体用于:
[0054] 基于所述同步策略,确定所述任一第一制品对应的数据同步方式;
[0055] 采用所述数据同步方式,将所述任一第一制品同步分发到所述至少一个目标节点;或,
[0056] 所述处理单元具体用于:
[0057] 基于所述调度策略,确定所述任一第一制品对应的数据同步方式;
[0058] 基于所述同步策略,确定所述任一第一制品对应的数据同步方式;
[0059] 结合采用所述同步方式和所述数据同步方式,将所述任一第一制品同步分发到所述至少一个目标节点。
[0060] 在一种可能的设计中,所述调度策略还包括:冲突处理方式、错误处理方式和执行方式中的一种或多种;
[0061] 所述冲突处理方式包括:选择跳过、覆盖、快速失败中的一种;
[0062] 所述错误处理方式包括:选择继续执行、快速失败中的一种;
[0063] 所述执行方式包括:选择继续执行或快速失败中的一种。
[0064] 在一种可能的设计中,所述第一同步结果包括成功数量、失败数量、冲突数量和所述任一第一制品的同步结果;所述成功数量为同步分发成功的第一制品对应的数量;所述
失败数量为同步分发失败的第一制品对应的数量;所述成功数量为同步分发冲突的第一制
品对应的数量。
[0065] 第三方面,本申请实施例提供一种基于DevOps的制品同步设备,所述基于DevOps的制品同步设备包括:至少一个存储器和至少一个处理器;
[0066] 所述至少一个存储器用于存储一个或多个程序;
[0067] 当所述一个或多个程序被所述至少一个处理器执行时,实现上述第一方面中任一种可能设计所涉及的方法。
[0068] 第四方面,本申请实施例提供一种计算机可读存储介质,所述计算机可读存储介质存储有至少一个程序;当所述至少一个程序被处理器执行时,实现上述第一方面中任一
种可能设计所涉及的方法。
[0069] 本申请的有益效果如下:
[0070] 在本申请提供的技术方案中,创建多个节点,多个节点中的部分节点用于同步分发任一制品;进一步的,获取用户的第一操作信息,并基于第一操作信息,确定待分发的任
一第一制品对应的至少一个目标节点;多个节点包括至少一个目标节点;进一步的,获取待
执行的同步计划,同步计划为用于同步分发任一第一制品时的计划;进一步的,执行同步计
划,将任一第一制品同步分发到至少一个目标节点,获得任一第一制品对应的第一同步结
果;进一步的,输出第一同步结果。通过这种方式,可以不依赖现有的制品同步分发人物的
定时同步框架/工具,便可以实现任一制品的自动同步分发,可以解决网络分区和带宽限制
等一系列问题,还可以解决现有技术中存在的制品的分发同步需要用户频繁的手动操作,
操作较繁琐的问题,可以解放用户的双手,可以实现高效的制品同步分发,从而可以提高软
件产品的生产力。

附图说明

[0071] 图1为本申请实施例提供的一种基于DevOps的制品同步方法的流程示意图;
[0072] 图2为本申请实施例提供的一种基于DevOps的制品同步设备的结构示意图;
[0073] 图3为本申请实施例提供的一种基于DevOps的制品同步设备的结构示意图。

具体实施方式

[0074] 为了便于理解本申请实施例提供的技术方案,下面结合附图详细说明本申请的技术方案。
[0075] 以下示例性实施例中所描述的实施方式并不代表与本申请相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本申请的一些方面相一致的方法的例
子。
[0076] 在本申请使用的术语是仅仅出于描述特定实施例的目的,而非旨在限制本申请。在本申请和所附权利要求书中所使用的单数形式的“一种”、“所述”和“该”也旨在包括多数
形式,除非上下文清楚地表示其他含义。还应当理解,本文中使用的术语“和/或”是指并包
含一个或多个相关联的列出项目的任何或所有可能组合。还应理解,本文中使用的术语“至
少一个”包括一个或多个,“多个”包括两个及两个以上。
[0077] 除非有相反的说明,本申请实施例提及“第一”等序数词用于对多个对象进行区分,不用于限定多个对象的顺序、时序、优先级或者重要程度。
[0078] 本申请实施例所涉及的DevOps(为Development和Operations的组合词)是一组过程、方法与系统的统称,可以透过自动化“软件交付”和“架构变更”的流程,来使得构建、测
试、发布软件能够更加地快捷、频繁和可靠。
[0079] 本申请实施例所涉及的边缘节点,与主节点属于同一套集群环境不同区域,共享同一套数据库。
[0080] 本申请实施例所涉及的独立节点,与主节点属于不同集群环境,不共享数据库。
[0081] 下面将结合图1对本申请实施例提供的基于DevOps的制品同步方法进行具体阐述。
[0082] 请参考图1所示,为本申请实施例提供的一种基于DevOps的制品同步方法的流程示意图。如图1所示,该方法流程可以包括以下步骤:
[0083] S101、创建多个节点。
[0084] 在一些实施例中,多个节点中的部分节点可以用于同步分发任一制品。其中,多个节点中的任一节点可以为边缘节点、远程节点、独立节点、中心节点中的一个节点。边缘节
点和独立节点可以属于从节点,中心节点可以属于主节点。
[0085] 在一些实施例中,基于DevOps的制品同步设备可以采用边缘节点模式创建多个节点。其中,当采用边缘节点模式创建多个节点时,多个节点中的任一对主从节点之间可以共
享数据库,并在同步分发制品时把Blob数据分发到多个节点中的边缘节点。
[0086] 在另一些实施例中,基于DevOps的制品同步设备可以采用独立节点模式创建多个节点。其中,当采用边缘节点模式创建多个节点时,多个节点中的主节点和多个节点中的独
立节点不共享数据库,并在同步分发制品时把metadata数据和blob数据给多个节点中的独
立节点。
[0087] 在具体的实现过程中,基于DevOps的制品同步设备可以提供节点创建页面。用户可以在该节点创建页面上,配置边缘节点、远程节点、独立节点、主节点和从节点等节点以
及节点的创建模式(包括边缘节点模式和独立节点模式)的配置信息。之后,基于DevOps的
制品同步设备可以基于该配置信息,创建多个节点。
[0088] 本申请实施例中,通过采用相应的创建模式创建多个节点,可以在制品同步分发过程中,存在既需要往其它节点去分发制品,也需要其它节点拉取制品时,主动代理主节点
去拉取制品,还可以支持在集群内的制品同步分发和集群之间的制品同步分发。
[0089] 在一些实施例中,基于DevOps的制品同步设备在完成创建多个节点后,可以测试多个节点中的远程节点和多个节点中的主节点之间的连接是否可用。当确定多个节点中的
远程节点和多个节点中的主节点之间的连接不可用时,基于DevOps的制品同步设备可以输
出提示信息,用于提示多个节点中的远程节点和多个节点中的主节点之间的连接不可用,
便于用户及时发现连接不可用的远程节点和主节点。
[0090] 在具体的实现过程中,该提示信息可以具体提示多个节点中的远程节点和多个节点中的主节点之间的连接不可用的原因、解决该原因的措施等,本申请实施例不限定。
[0091] 本申请实施例中,通过测试多个节点中的远程节点和多个节点中的主节点之间的连接是否可用,可以确保多个节点之间的通信正常。
[0092] S102、获取用户的第一操作信息,并基于第一操作信息,确定待分发的任一第一制品对应的至少一个目标节点。
[0093] 在一些实施例中,基于DevOps的制品同步设备可以提供目标节点的选择页面。用户可以在该选择页面上,进行选择需要同步的目标节点的第一操作。比如,用户可以在该选
择页面上从多个节点中选择出至少一个目标节点。之后,基于DevOps的制品同步设备可以
基于该第一操作,获取到第一操作信息。之后,基于DevOps的制品同步设备可以基于第一操
作信息,确定任一第一制品对应的至少一个目标节点。即第一操作信息为用于确定任一第
一制品对应的至少一个目标节点的信息。
[0094] 本申请实施例中,通过提供目标节点的选择页面,可以满足用户对选择需要同步的目标节点的不同要求,有助于提升用户的体验。
[0095] S103、获取待执行的同步计划。
[0096] 在一些实施例中,该同步计划可以为用于同步分发任一第一制品时的计划。
[0097] 在一些实施例中,基于DevOps的制品同步设备可以提供制品同步分发的计划创建页面。用户可以在该计划创建页面上,进行该同步计划的基本信息的填写操作。基于DevOps
的制品同步设备可以基于该填写操作,获得该同步计划。其中,该基本信息包括名称、描述、
内容,以及同步分发任一第一制品时将采用的调度策略、同步策略和执行策略(将在下文具
体介绍)等,本申请实施例不限定。
[0098] 本申请实施例中,通过提供制品同步分发的计划创建页面,可以满足用户对不同制品的同步分发要求,有助于提升用户的体验。
[0099] S104、执行同步计划,将任一第一制品同步分发到至少一个目标节点,获得任一第一制品对应的第一同步结果。
[0100] 在一些实施例中,上述执行策略可以包括但不限于:调度同步方式和实时同步方式。调度同步方式可以是根据调度策略去进行制品的同步分发的方式。实时同步方式可以
是根据主节点上制品的新增,触发进行制品的同步分发的方式。
[0101] 在一些实施例中,基于DevOps的制品同步设备可以确定任一第一制品是否为多个节点中的主节点上新增的制品,再基于上述执行策略,采用相应的方式将任一第一制品同
步分发到至少一个目标节点。
[0102] 比如,若确定任一第一制品是多个节点中的主节点新增的制品,基于DevOps的制品同步设备则可以基于该执行策略,确定执行该同步策略。比如,基于DevOps的制品同步设
备则可以基于该执行策略中的实时同步方式,确定执行该同步策略。之后,基于DevOps的制
品同步设备可以基于该同步策略,将任一第一制品同步分发到至少一个目标节点。
[0103] 或者,若确定任一第一制品不是多个节点中的主节点新增的制品,基于DevOps的制品同步设备则可以基于该执行策略,确定执行该调度策略和该调度策略。比如,基于
DevOps的制品同步设备可以基于该执行策略中的调度同步方式,确定执行该调度策略和该
同步策略。之后,基于DevOps的制品同步设备可以结合该调度策略和该同步策略,将任一第
一制品同步分发到至少一个目标节点。
[0104] 本申请实施例中,通过确定任一第一制品是否为多个节点中的主节点新增的制品,再采用相应的方式,将任一第一制品同步分发到至少一个目标节点,可以主动地将主节
点上新增的制品同步到目标节点上,无需用户手动频繁地将主节点上新增的制品同步分发
到目标节点上,可以解放用户的双手,可以实现高效的制品同步分发,从而可以提高软件产
品的生产力。
[0105] 在一些实施例中,上述调度策略可以包括任一第一制品对应的同步方式。其中,该同步方式可以包括但不限于:立即同步方式、指定时间同步方式和定时同步方式中的一种。
该立即同步方式可以是立即将制品同步分发到目标节点的方式。该指定时间同步方式可以
是在指定时间将制品同步分发到目标节点的方式。该定时同步方式可以是按照经过预设时
长后将制品同步分发到目标节点的方式。在具体的实现过程中,指定时间和预设时长可以
根据实际需求进行设定,本申请实施例不限定。
[0106] 在一些实施例中,上述同步策略可以包括:任一第一制品对应的数据同步方式,其中,该数据同步方式可以包括但不限于:按照仓库同步方式、按照制品同步方式和按照文件
同步方式中的一种。该按照仓库同步方式可以是将制品仓库中的所有制品(包括任一第一
制品)都同步到目标节点的方式。该按照制品同步方式可以是只将任一制品同步到目标节
点的方式。该按照文件同步方式,可以是将任一第一制品对应的多个文件分别同步到目标
节点的方式。
[0107] 在基于DevOps的制品同步设备基于该同步策略,将任一第一制品同步分发到至少一个目标节点的过程中,基于DevOps的制品同步设备可以基于同步策略,确定任一第一制
品对应的数据同步方式。之后,基于DevOps的制品同步设备可以采用该数据同步方式,将任
一第一制品同步分发到至少一个目标节点。
[0108] 在基于DevOps的制品同步设备结合该调度策略和该同步策略,将任一第一制品同步分发到至少一个目标节点的过程中,基于DevOps的制品同步设备可以基于该调度策略,
确定任一第一制品对应的数据同步方式,以及,可以基于该同步策略,确定任一第一制品对
应的数据同步方式。之后,基于DevOps的制品同步设备可以结合采用该同步方式和该数据
同步方式,将任一第一制品同步分发到至少一个目标节点。
[0109] 在一些实施例中,基于DevOps的制品同步设备将任一第一制品同步分发到至少一个目标节点后,可以获得任一第一制品对应的第一同步结果。
[0110] 在一些实施例中,该调度策略还可以包括但不限于:冲突处理方式、错误处理方式和执行方式。
[0111] 在具体的实现过程中,冲突处理方式可以包括但不限于:选择跳过、覆盖、快速失败中的一种。该选择跳过方式为在将任一第一制品同步分发到至少一个目标节点过程中,
若存在相互冲突的第一制品时,选择跳过同步分发相互冲突的第一制品,继续同步分发其
它不冲突的第一制品到至少一个目标节点中的方式。该覆盖方式为在将任一第一制品同步
分发到至少一个目标节点过程中,若存在相互冲突的第一制品时,选择将相互冲突的第一
制品中的一个第一制品覆盖其它第一制品,同步分发该第一制品和其它不冲突的第一制品
到至少一个目标节点中的方式。其中,其它第一制品为相互冲突的第一制品中除去该第一
制品之外的第一制品。该快速失败方式为在将任一第一制品同步分发到至少一个目标节点
过程中,若存在相互冲突的第一制品时,选择将相互冲突的第一制品确定为同步分发失败
的第一制品的方式。
[0112] 在具体的实现过程中,错误处理方式可以包括但不限于:选择继续执行、快速失败中的一种。该选择继续执行方式为在将任一第一制品同步分发到至少一个目标节点过程
中,若存在同步分发错误的第一制品时,选择继续同步分发该第一制品到至少一个目标节
点中的方式。该快速失败方式为在将任一第一制品同步分发到至少一个目标节点过程中,
若存在同步分发错误的第一制品时,将该第一制品确定为同步分发失败的第一制品的方
式。
[0113] 在具体地实现过程中,执行方式可以包括但不限于:选择继续执行或快速失败中的一种。该选择继续执行方式为在将任一第一制品同步分发到至少一个目标节点过程中,
选择继续将任一第一制品同步分发到至少一个目标节点过程中的方式。该快速失败方式为
在将任一第一制品同步分发到至少一个目标节点过程中,选择将正在分发和/或还未分发
的第一制品确定为同步失败的第一制品的方式。
[0114] 本申请实施例中,基于DevOps的制品同步设备通过在将任一第一制品同步分发到至少一个目标节点的过程中,执行冲突处理方式、错误处理方式和执行方式中的一种或多
种,可以解决在将任一第一制品同步分发到至少一个目标节点的过程中出现的冲突或者错
误等问题,可以实现高效的制品同步分发,从而可以提高软件产品的生产力。
[0115] 在一些实施例中,基于DevOps的制品同步设备通过在将任一第一制品同步分发到至少一个目标节点的过程中,还可以对节点进行限速,比如对至少一个目标节点进行限速,
可以避免出现某个第一制品为大文件时占用过大的带宽而导致网络卡顿的问题,从而可以
实现高效的制品同步分发。
[0116] 本申请实施例中,只需要用户简单的创建任一制品的同步计划,再由基于DevOps的制品同步设备通过执行同步计划,将任一第一制品同步分发到至少一个目标节点,可以
不依赖现有的制品同步分发人物的定时同步框架/工具,便可以实现任一制品的自动同步
分发,可以解决网络分区和带宽限制等一系列问题,还可以解决现有技术中存在的制品的
分发同步需要用户频繁的手动操作,操作较繁琐的问题,可以解放用户的双手,可以实现高
效的制品同步分发,从而可以提高软件产品的生产力。
[0117] S105、输出第一同步结果。
[0118] 在一些实施例中,第一同步结果可以包括成功数量、失败数量、冲突数量和任一第一制品的同步结果。其中,成功数量可以为同步分发成功的第一制品对应的数量。失败数量
可以为同步分发失败的第一制品对应的数量。成功数量可以为同步分发冲突的第一制品对
应的数量。
[0119] 在一些实施例中,基于DevOps的制品同步设备可以在显示页面上显示第一同步结果。
[0120] 本申请实施例中,基于DevOps的制品同步设备通过输出第一同步结果,可以便于用户查看待分发的第一制品对应的成功数量、失败数量、冲突数量和任一第一制品的同步
结果,以使用户可以去从节点上任一第一制品是否存在以及任一第一制品的相关信息,可
以确保任一第一制品是否已经分发到相应的目标节点上。
[0121] 通过以上描述内容可知,在本申请实施例提供的技术方案中,创建多个节点,多个节点中的部分节点用于同步分发任一制品;进一步的,获取用户的第一操作信息,并基于第
一操作信息,确定待分发的任一第一制品对应的至少一个目标节点;多个节点包括至少一
个目标节点;进一步的,获取待执行的同步计划,同步计划为用于同步分发任一第一制品时
的计划;进一步的,执行同步计划,将任一第一制品同步分发到至少一个目标节点,获得任
一第一制品对应的第一同步结果;进一步的,输出第一同步结果。通过这种方式,可以不依
赖现有的制品同步分发人物的定时同步框架/工具,便可以实现任一制品的自动同步分发,
可以解决网络分区和带宽限制等一系列问题,还可以解决现有技术中存在的制品的分发同
步需要用户频繁的手动操作,操作较繁琐的问题,可以解放用户的双手,可以实现高效的制
品同步分发,从而可以提高软件产品的生产力。
[0122] 基于同一发明构思,本申请实施例还提供一种基于DevOps的制品同步设备,如图2所示,基于DevOps的制品同步设备200可以包括:
[0123] 创建单元201,用于创建多个节点,所述多个节点中的部分节点用于同步分发任一制品;
[0124] 接收单元202,用于获取用户的第一操作信息,并基于所述第一操作信息,确定待分发的任一第一制品对应的至少一个目标节点;所述多个节点包括所述至少一个目标节
点;获取待执行的同步计划,所述同步计划为用于同步分发所述任一第一制品时的计划;
[0125] 处理单元203,用于执行所述同步计划,将所述任一第一制品同步分发到所述至少一个目标节点,获得所述至少一个第一制品对应的第一同步结果;
[0126] 输出单元204,用于输出所述第一同步结果。
[0127] 在一种可能的设计中,所述多个节点中的任一节点为边缘节点、远程节点、独立节点、中心节点中的一个节点;所述边缘节点和所述独立节点属于从节点,所述中心节点属于
主节点;所述创建单元201具体用于:
[0128] 采用边缘节点模式或独立节点模式创建所述多个节点;其中,
[0129] 当所述创建单元201采用所述边缘节点模式创建所述多个节点时,所述多个节点中的任一对主从节点之间共享数据库,并在同步分发制品时把Blob数据分发到所述多个节
点中的边缘节点;
[0130] 当所述创建单元201采用所述独立节点模式创建所述多个节点时,所述多个节点中的主节点和所述多个节点中的独立节点不共享数据库,并在同步分发制品时把metadata
数据和所述blob数据给所述多个节点中的独立节点。
[0131] 在一种可能的设计中,获取用户的第一操作信息之前,所述处理单元203还用于:测试所述多个节点中的远程节点和所述多个节点中的主节点之间的连接是否可用;
[0132] 所述输出单元204还有用于:当所述处理单元203确定所述多个节点中的远程节点和所述多个节点中的主节点之间的连接不可用时,输出提示信息,用于提示所述多个节点
中的远程节点和所述多个节点中的主节点之间的连接不可用。
[0133] 在一种可能的设计中,所述同步计划包括:同步分发所述任一第一制品时将采用的调度策略、同步策略和执行策略;所述处理单元203具体用于:
[0134] 确定所述任一第一制品是否为所述多个节点中的主节点上新增的制品;
[0135] 若确定所述任一第一制品是所述多个节点中的主节点上新增的制品,则基于所述执行策略,确定执行所述同步策略;基于所述同步策略,将所述任一第一制品同步分发到所
述至少一个目标节点;或者,
[0136] 若确定所述任一第一制品不是所述多个节点中的主节点上新增的制品,则基于所述执行策略,确定执行所述调度策略和所述调度策略;结合所述调度策略和所述同步策略,
将所述任一第一制品同步分发到所述至少一个目标节点。
[0137] 在一种可能的设计中,所述调度策略包括所述任一第一制品对应的同步方式,所述同步方式包括:立即同步方式、指定时间同步方式和定时同步方式中的一种;所述同步策
略包括所述任一第一制品对应的数据同步方式,所述数据同步方式包括:按照仓库同步方
式、按照制品同步方式和按照文件同步方式中的一种。
[0138] 在一种可能的设计中,所述处理单元203具体用于:
[0139] 基于所述同步策略,确定所述任一第一制品对应的数据同步方式;
[0140] 采用所述数据同步方式,将所述任一第一制品同步分发到所述至少一个目标节点;或,
[0141] 所述处理单元203具体用于:
[0142] 基于所述调度策略,确定所述任一第一制品对应的数据同步方式;
[0143] 基于所述同步策略,确定所述任一第一制品对应的数据同步方式;
[0144] 结合采用所述同步方式和所述数据同步方式,将所述任一第一制品同步分发到所述至少一个目标节点。
[0145] 在一种可能的设计中,所述调度策略还包括:冲突处理方式、错误处理方式和执行方式中的一种或多种;
[0146] 所述冲突处理方式包括:选择跳过、覆盖、快速失败中的一种;
[0147] 所述错误处理方式包括:选择继续执行、快速失败中的一种;
[0148] 所述执行方式包括:选择继续执行或快速失败中的一种。
[0149] 在一种可能的设计中,所述第一同步结果包括成功数量、失败数量、冲突数量和所述任一第一制品的同步结果;所述成功数量为同步分发成功的第一制品对应的数量;所述
失败数量为同步分发失败的第一制品对应的数量;所述成功数量为同步分发冲突的第一制
品对应的数量。
[0150] 本申请实施例中的基于DevOps的制品同步设备200与上述图1所示的基于DevOps的制品同步方法是基于同一构思下的发明,通过前述对基于DevOps的制品同步方法的详细
描述,本领域技术人员可以清楚的了解本实施例中基于DevOps的制品同步设备200的实施
过程,所以为了说明书的简洁,在此不再赘述。
[0151] 基于同一发明构思,本申请实施例还提供一种基于DevOps的制品同步设备,如图3所示,基于DevOps的制品同步设备300可以包括:至少一个存储器301和至少一个处理器
302。其中:
[0152] 至少一个存储器301用于存储一个或多个程序。
[0153] 当一个或多个程序被至少一个处理器302执行时,实现上述图1所示的基于DevOps的制品同步方法。
[0154] 基于DevOps的制品同步设备300还可以可选地包括通信接口(图3中未示出),通信接口用于与外部设备进行通信和数据交互传输。
[0155] 需要说明的是,存储器301可能包含高速RAM存储器,也可能还包括非易失性存储器 (nonvolatile memory),例如至少一个磁盘存储器。
[0156] 在具体的实现过程中,如果存储器、处理器及通信接口集成在一块芯片上,则存储器、处理器及通信接口可以通过内部接口完成相互间的通信。如果存储器、处理器和通信接
口独立实现,则存储器、处理器和通信接口可以通过总线相互连接并完成相互间的通信。
[0157] 基于同一发明构思,本申请实施例还提供一种计算机可读存储介质,该计算机可读存储介质可以存储有至少一个程序,当至少一个程序被处理器执行时,实现上述图1所示
的基于DevOps的制品同步方法。
[0158] 应当理解,计算机可读存储介质为可存储数据或程序的任何数据存储设备,数据或程序其后可由计算机系统读取。计算机可读存储介质的示例包括:只读存储器、随机存取
存储器、CD‑ROM、HDD、DVD、磁带和光学数据存储设备等。
[0159] 计算机可读存储介质还可分布在网络耦接的计算机系统中使得计算机可读代码以分布式方式来存储和执行。
[0160] 计算机可读存储介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、射频(Radio Frequency,RF)等,或者上述的任意合适的组合。
[0161] 以上实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对申请专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在
不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。