一种数据同步方法、装置、电子设备及介质与流程

文档序号:31450523发布日期:2022-09-07 13:08阅读:78来源:国知局
一种数据同步方法、装置、电子设备及介质与流程

1.本技术涉及数据处理领域,具体而言,涉及一种数据同步方法、装置、电子设备及介质。


背景技术:

2.对于应用开发商来说,想要在企业微信、钉钉等业务管理平台上打造一个完善的系统,就离不开企业微信、钉钉等业务管理平台的数据支持,那么数据的准确性就是开发商需要优先保证的。
3.由于在进行系统部署时,客户是否存在既有业务管理平台的数据是不确定的,为了能够提供稳定服务,系统首先需要有基于业务管理平台进行数据全量同步的能力。在后续的数据同步中,为了保证性能以及资源的合理利用,系统需要具备通过基于业务管理平台回调,完成数据增量同步的能力。
4.在应用进行全量数据同步的过程中,下游业务功能难免会收到影响,如果全量同步数据所需耗时过久,就会导致业务受阻,因此,如何在有限的资源下,尽快的完成对业务管理平台数据的全量同步、以及保证数据的准确性,就成为了亟待解决的问题。


技术实现要素:

5.有鉴于此,本技术的目的在于提供一种数据同步方法,通过事件分发的方式对同步任务进行分治,让集群中的每一个服务节点都能够参与到数据的同步中,提高数据同步的速度。
6.本技术实施例提供的一种数据同步方法,应用于同步平台,所述同步平台包括分发节点和多个服务节点;所述方法包括以下步骤:
7.所述多个服务节点中的任一服务节点在接收到针对目标数据的同步触发信息后,根据所述同步触发信息的类型,确定待同步的当前层级数据标识,并从所述目标数据所在目标服务器中获取所述当前层级数据标识对应的当前层级目标数据;
8.获取到当前层级目标数据的服务节点根据所述当前层级目标数据,确定所述当前层级数据标识的下一级数据标识,并将所述下一级数据标识发送给所述分发节点;
9.所述分发节点根据所述下一级数据标识确定同步任务,并将所述同步任务分发至所述多个服务节点;
10.所述多个服务节点根据接收到的同步任务确定下一级数据标识,从所述目标服务器中获取所述下一级数据标识对应的下一级目标数据,以将所述目标服务器中的下一级目标数据同步到所述服务节点中。
11.在一些实施例中,所述的数据同步方法中,根据所述同步触发信息的类型,确定待同步的当前层级数据标识,包括:
12.当所述同步触发信息为终端发送的全量数据更新请求时,根据预先配置的目标数据的数据层级结构,确定待同步的当前层级数据标识;
13.当所述同步触发信息为分发节点发送的同步任务时,从所述同步任务中提取出待同步的当前层级数据标识。
14.在一些实施例中,所述的数据同步方法中,将所述下一级数据标识发送给所述分发节点,包括:
15.当下一级数据标识对应多种类型的下一级目标数据时,将所述下一级数据标识分别发送至所述分发节点的预先配置的对应类型的消息队列中;
16.所述分发节点根据所述下一级数据标识确定同步任务,并将所述同步任务分发至所述多个服务节点,包括:
17.所述分发节点根据每种类型的消息队列,确定每种类型的同步任务,并根据同步任务生成的顺序依次将每种类型的同步任务分发至服务节点。
18.在一些实施例中,所述的数据同步方法还包括以下步骤:
19.所述同步平台响应接收到全量数据更新请求,创建全量更新锁,以在所述全量更新锁存在时,停止处理接收到的增量数据更新事件;
20.所述同步平台响应目标数据同步完成,释放所述全量更新锁,以开始处理在全量数据同步期间接收到的增量数据更新事件。
21.在一些实施例中,所述的数据同步方法中,所述同步平台响应目标数据同步完成,释放所述全量更新锁,以开始处理在全量数据同步期间接收到的增量数据更新事件,包括:
22.响应释放所述全量更新锁,同步平台的每个服务节点根据记录的增量数据更新事件的状态标识,确定该服务节点中处于未处理状态增量数据更新事件;其中,所述状态标识是根据该服务节点接收到增量数据更新事件时,根据是否存在全量更新锁为所述增量数据更新事件添加的;
23.所述每个服务节点获取目标服务器中增量数据更新事件对应的数据,以完成全量数据同步期间的增量数据更新事件。
24.在一些实施例中,所述的数据同步方法中,所述同步平台的服务节点接收到的增量数据更新事件,是通过以下方法获取的:
25.所述同步平台的目标服务节点接收到目标服务器推送的增量数据更新事件;
26.所述同步平台的目标服务节点根据接收到的增量数据更新事件发送至分发节点,以使所述分发节点将所述增量数据更新事件重新分发至同步平台中的任一服务节点,以使每个服务节点中的增量数据更新事件数量均衡。
27.在一些实施例中,所述的数据同步方法中,所述目标数据为业务管理平台的目标服务器中储存的、目标企业的目标数据。
28.在一些实施例中,还提供一种数据同步装置,应用于同步平台,所述同步平台包括分发节点和多个服务节点;所述装置包括:
29.第一获取模块,用于在所述多个服务节点中的任一服务节点在接收到针对目标数据的同步触发信息后,根据所述同步触发信息的类型,确定待同步的当前层级数据标识,并从所述目标数据所在目标服务器中获取所述当前层级数据标识对应的当前层级目标数据;
30.发送模块,用于使获取到当前层级目标数据的服务节点根据所述当前层级目标数据,确定所述当前层级数据标识的下一级数据标识,并将所述下一级数据标识发送给所述分发节点;
31.分发模块,用于使所述分发节点根据所述下一级数据标识确定同步任务,并将所述同步任务分发至所述多个服务节点;
32.第二获取模块,用于使所述多个服务节点根据接收到的同步任务确定下一级数据标识,从所述目标服务器中获取所述下一级数据标识对应的下一级目标数据,以将所述目标服务器中的下一级目标数据同步到所述服务节点中。
33.在一些实施例中,还提供一种电子设备,包括:处理器、存储器和总线,所述存储器存储有所述处理器可执行的机器可读指令,当电子设备运行时,所述处理器与所述存储器之间通过总线通信,所述机器可读指令被所述处理器执行时执行所述的数据同步方法的步骤。
34.在一些实施例中,还提供一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,该计算机程序被处理器运行时执行所述的数据同步方法的步骤。
35.本技术实施例提供一种数据同步方法,将全量同步任务进行拆分,拆分为多个细粒度的同步块,并分发到集群中的多个服务节点上,通过事件分发的方式对同步任务进行分治,使得多个服务节点同时进行数据全量同步任务,让整个集群能够协同完成全量同步任务,解决了现有方案中同步任务只能由单台节点完成的问题,合理的利用有限的资源,加快了全量数据同步的速度。
36.进一步的,在全量数据同步开始时,设置全量同步锁,停止对增量数据同步的处理,并在全量数据同步结束后,通过对企业微信的接口回调进行梳理,提供了回放历史事件,准确更新增量数据的能力,保证了全量同步与增量同步的数据准确性。
附图说明
37.为了更清楚地说明本技术实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本技术的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
38.图1示出了本技术实施例中所述数据同步方法的方法流程图;
39.图2示出了本技术实施例的所述同步平台的结构示意图;
40.图3示出了本技术实施例所述企业微信的全量数据同步的流程示意图;
41.图4示出了本技术实施例中所述另一种数据同步方法的方法流程图;
42.图5示出了本技术实施例中所述同步平台的服务节点接收到的增量数据更新事件的方法流程图;
43.图6示出了本技术实施例所述一种数据同步装置的结构示意图;
44.图7示出了本技术实施例所述一种电子设备的结构示意图。
具体实施方式
45.为使本技术实施例的目的、技术方案和优点更加清楚,下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行清楚、完整地描述,应当理解,本技术中附图仅起到说明和描述的目的,并不用于限定本技术的保护范围。另外,应当理解,示意性的附图并未按实物比例绘制。本技术中使用的流程图示出了根据本技术的一些实施例实现的操
作。应该理解,流程图的操作可以不按顺序实现,没有逻辑的上下文关系的步骤可以反转顺序或者同时实施。此外,本领域技术人员在本技术内容的指引下,可以向流程图添加一个或多个其他操作,也可以从流程图中移除一个或多个操作。
46.另外,所描述的实施例仅仅是本技术一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本技术实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本技术的实施例的详细描述并非旨在限制要求保护的本技术的范围,而是仅仅表示本技术的选定实施例。基于本技术的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本技术保护的范围。
47.需要说明的是,本技术实施例中将会用到术语“包括”,用于指出其后所声明的特征的存在,但并不排除增加其它的特征。
48.对于应用开发商来说,想要在企业微信、钉钉等业务管理平台上打造一个完善的系统,就离不开企业微信、钉钉等业务管理平台的数据支持,那么数据的准确性就是开发商需要优先保证的。
49.以企业微信为例,企业微信当前提供了批量获取指定范围内通讯录、客户联系等数据的接口,以及通过接口回调的方式,提供了通讯录、客户联系数据的增量同步能力。
50.由于在进行系统部署时,客户是否存在企业微信的数据是不确定的,为了能够提供稳定服务,系统首先需要有基于企业微信进行数据全量同步的能力。在后续的数据同步中,为了保证性能以及资源的合理利用,系统需要具备通过基于企业微信回调,完成数据增量同步的能力。
51.在应用进行全量数据同步的过程中,下游业务功能难免会收到影响,如果全量同步数据所需耗时过久,就会导致业务受阻。但是现有的数据全量同步的过程如下:当应用开发商的同步平台中触发全量同步请求后,由网关将请求路由至一台机器上,之后会在这台机器上调用企业微信接口,拉取企业微信数据并与本地数据进行比对,完成数据的全量同步。也就是说,当触发全量同步请求后,针对部门员工信息、客户信息、客户群信息等类型的信息,都是一次性获取全部信息。具体来说,当部门员工全量更新开始后,一次性获取并更新企业组织架构,并按照组织架构的部门获取员工详情信息;当员工信息全量同步开始后,一次性获取系统内员工列表,并通过员工列表,获取所有客户列表(仅id),再根据客户id,获取客户详情,更新客户信息;当客户群信息全量同步开始后,一次性获取系统内员工列表,通过员工列表,获取所有客户群列表,再根据客户群列表,获取客户群详情并更新。整个过程最终只会有一台机器(所述机器又可称之为服务器、服务、节点、服务节点)参与到全量同步中,导致全量同步的性能受到单台机器性能瓶颈影响严重,效率难以提升。对于进行全量同步的服务来说,资源消耗多,压力大,同步会出现风险。
52.因此,如何在有限的资源下,尽快的完成对业务管理平台数据的全量同步、以及保证数据的准确性,就成为了亟待解决的问题。
53.基于此,本技术实施例提供一种数据同步方法,将全量同步任务进行拆分,拆分为多个细粒度的同步块,并分发到集群中的多个服务节点上,通过事件分发的方式对同步任务进行分治,使得多个服务节点同时进行数据全量同步任务,让整个集群能够协同完成全量同步任务,解决了现有方案中同步任务只能由单台节点完成的问题,合理的利用有限的资源,加快了全量数据同步的速度。
54.请参照图1,图1示出了本技术实施例中所述数据同步方法的方法流程图;具体的,所述数据同步方法,应用于同步平台,所述同步平台包括分发节点和多个服务节点;所述方法包括以下步骤:
55.s101、所述多个服务节点中的任一服务节点在接收到针对目标数据的同步触发信息后,根据所述同步触发信息的类型,确定待同步的当前层级数据标识,并从所述目标数据所在目标服务器中获取所述当前层级数据标识对应的当前层级目标数据;
56.s102、获取到当前层级目标数据的服务节点根据所述当前层级目标数据,确定所述当前层级数据标识的下一级数据标识,并将所述下一级数据标识发送给所述分发节点;
57.s103、所述分发节点根据所述下一级数据标识确定同步任务,并将所述同步任务分发至所述多个服务节点;
58.s104、所述多个服务节点根据接收到的同步任务确定下一级数据标识,从所述目标服务器中获取所述下一级数据标识对应的下一级目标数据,以将所述目标服务器中的下一级目标数据同步到所述服务节点中。
59.请参照图2,图2示出了本技术实施例的所述同步平台的结构示意图。所述同步平台包括多个服务节点201和分发节点202,其中的一个服务节点通过网关203与终端204通讯连接;每个服务节点201与分发节点202通讯连接;每个服务节点201均与目标服务器205通讯连接。
60.其中,所述目标服务器为业务管理平台的服务器,所述业务管理平台用于管理企业业务。示例性的,所述业务管理平台包括钉钉、企业微信等,所述分发节点采用kafka。
61.在所述步骤s101中,所述多个服务节点中的任一服务节点在接收到针对目标数据的同步触发信息后,根据所述同步触发信息的类型,确定待同步的当前层级数据标识,并从所述目标数据所在目标服务器中获取所述当前层级数据标识对应的当前层级目标数据。
62.具体的,所述根据所述同步触发信息的类型,确定待同步的当前层级数据标识,包括:
63.当所述同步触发信息为终端发送的全量数据更新请求时,根据预先配置的目标数据的数据层级结构,确定待同步的当前层级数据标识;
64.当所述同步触发信息为分发节点发送的同步任务时,从所述同步任务中提取出待同步的当前层级数据标识。
65.也就是说,所述同步触发信息包括两种类型:终端发送的全量数据更新请求或者分发节点发送的任务。这两种不同类型的同步触发信息在整个同步任务的不同阶段。
66.终端发送的全量数据更新请求,用于触发全量数据同步这一整体的同步任务。在触发全量数据同步这一整体的同步任务后,所述同步平台创建全量更新版本号。
67.这里,与终端通讯连接的服务节点称之为第一个服务节点,以便于技术方案的说明,所述同步平台中的第一个服务节点接收到终端发送的全量数据更新请求,则确定目标数据的数据层级结构为最高层级,并确定待同步的当前层级数据标识。
68.本技术实施例中,所述目标数据为业务管理平台的目标服务器中储存的、目标企业的目标数据。所述预先配置的目标数据的数据层级结构是根据目标企业的业务架构确定的。以企业微信为例,所述企业的业务架构包括部门、部门员工、部门员工添加的客户、部门员工管理的微信群。
69.示例性的,终端发送的全量数据更新请求触发全量数据同步这一整体的同步任务后,确定数据层级结构为部门级别,并确定当前层级数据标识为“部门标识”,调用企业微信接口拉取企微后台的该企业的组织架构;例如该企业的组织架构为销售部、业务部、工程部、生产部、品质部、管理部。
70.在一些实施例中,第一个服务节点接收到全量数据更新请求,并不直接调用企业微信接口拉取企微后台的该企业的组织架构;而是进行以下步骤:第一个服务节点发送全量数据更新消息至kafka平台,kafka平台将获取企业的组织架构的同步任务分发至任一个服务节点,接收到获取企业的组织架构的同步任务的服务节点,调用企业微信接口拉取企微后台的该企业的组织架构。
71.本技术实施例中,调用企业微信接口拉取企微后台的该企业的部门架构后,所述同步平台开启异步线程定时检测全量更新状态;并且,所述同步平台以最新版本号写入组织架构至本地库,并清理旧版本组织架构的脏数据。
72.在所述步骤s102中,获取到当前层级目标数据的服务节点根据所述当前层级目标数据,确定所述当前层级数据标识的下一级数据标识,并将所述下一级数据标识发送给所述分发节点。
73.示例性的,当第一个服务节点接收到企业的组织架构后,遍历组织架构各个部门id,并将各个部门id作为下一层级数据标识,以消息的形式发送至kafka,通过kafka将获取每个部门id下的部门员工列表事件分发至每个服务节点,即所述步骤s103所述的,所述分发节点根据所述下一级数据标识确定同步任务,并将所述同步任务分发至所述多个服务节点。
74.也就是说,根据当前数据层级,可以将下一个层级数据划分为若干个数据块,每一个数据块作为一个同步任务,并通过分发节点将所述同步任务分发至各个服务节点,使得多个服务节点同时获取该层级数据的多个数据块,提高同步效率。
75.这里,将所述同步任务分发至所述多个服务节点,要保证每个服务节点的同步任务数量均衡。
76.示例性的,当所述服务节点有10个时,将获取销售部员工列表任务、业务部员工列表任务、工程部员工列表任务、生产部员工列表任务、品质员工列表任务部、管理部员工列表任务分别分发至服务节点,例如分别分发至第一个服务节点—第六个服务节点。
77.所述步骤s104中,所述多个服务节点根据接收到的同步任务确定下一级数据标识,从所述目标服务器中获取所述下一级数据标识对应的下一级目标数据,以将所述目标服务器中的下一级目标数据同步到所述服务节点中。
78.这里,也就是步骤s101中所说的,同步触发信息为分发节点发送的同步任务。
79.示例性的,第六个服务节点接收到获取销售部员工列表的同步任务后,调用企业微信接口拉取销售部下员工列表信息;随后,第六个服务节点遍历销售部下员工id,并将销售部员工id作为下一级数据标识,以消息的形式发送至kafka,并通过kafka将获取下一层级目标数据的任务分发至各个服务节点。
80.在所述步骤s104中,若一个服务节点接收到多个同步任务,可以并行处理或串行处理。
81.至此,本技术实施例所述数据同步方法,每个服务节点根据接收到的同步触发信
息,确定出当前层级的数据标识,并根据当前层级的数据标识从目标服务器中拉起当前层级的数据,例如当前层级为获取企业组织架构,则从目标服务器中拉取企业组织架构信息,也即企业各个部门的信息;在获取当前层级的数据后,利用当前层级中数据的粒度,将当前层级数据对应的下一级数据划分为更细粒度的同步块,并将同步块分发到每个服务节点,使得每个服务节点均能从目标服务器中拉取同步块的目标数据;例如当获取企业各个部门的信息后,即根据将每个部门作为划分粒度,将每个部门下的员工列表作为一个同步块,并将同步块分发到每个服务节点,使得每个服务节点均能从目标服务器中拉取至少一个部门的员工列表。
82.也就是说,本技术实施例中,首先将目标数据,按照层级结构划分为多个层级,这是目标数据最粗粒度的同步块;上一个层级数据中可以提取出一个数据标识,用来区分下一层级的数据;在进行全量数据同步时,首先是按照数据层级,来逐层进行数据同步;其次,对于最高层级之外的其他层级,每个层级再划分成若干个同步块,获取更细粒度的数据同步块,再使每个服务节点拉取更细粒度的同步块的数据。
83.这里,在所述步骤s104执行完毕后,每个服务节点判断根据接收到的数据,判断是否存在下一级数据,若存在,则将该服务节点接收到的目标数据作为步骤s101中获取的当前层级目标数据,重复步骤s102-步骤s104。
84.本技术实施例中,获取员工列表信息后,存在下一层级数据,因此,将所述员工列表信息步骤s101中获取的当前层级目标数据,重复步骤s102-步骤s104。
85.具体的,本技术实施例表中,本技术实施例中,获取员工列表信息后,下一级目标数据分为三种类型:员工详情数据、员工管理的客户数据、员工管理的客户群数据。
86.基于此,本技术实施例所述的数据同步方法,将所述下一级数据标识发送给所述分发节点,包括:
87.当下一级数据标识对应多种类型的下一级目标数据时,将所述下一级数据标识分别发送至所述分发节点的预先配置的对应类型的消息队列中;
88.所述分发节点根据所述下一级数据标识确定同步任务,并将所述同步任务分发至所述多个服务节点,包括:
89.所述分发节点根据每种类型的消息队列,确定每种类型的同步任务,并根据同步任务生成的顺序依次将每种类型的同步任务分发至服务节点。
90.也就是说,分别将员工id以消息的形式发送至kafka员工详情、员工管理的客户列表、员工管理的群列表这第三个队列中,kafka将获取员工详情、获取员工客户数据、获取客户群数据的同步任务,分别分发至每个服务节点。其中,获取一个员工id对应的员工详情,即为一个获取员工详情的同步任务;获取一个员工id对应的员工客户数据,即为一个获取员工客户数据的同步任务;获取一个员工id对应的客户群数据,即为一个获取客户群数据的同步任务。
91.以下分别说明每种类别的同步任务的数据获取流程。
92.服务节点接收到kafka平台分发的获取员工详情的同步任务后,调用企业微信接口获取员工详情信息,更新员工详情数据至本地库。所述员工详情,为该员工的具体信息,例如员工张三,联系方式12345678888,身份证号1234567888834456等。
93.服务节点接收到员工详情数据后,员工详情数据下不存在下一层级的数据,因此,
该同步任务不存在下一层级的同步任务。
94.服务节点接收到kafka平台分发的获取员工客户数据的同步任务后,调用企业微信接口获取客户列表信息,更新员工详情数据至本地库。
95.服务节点接收到员工客户数据后,员工客户数据下不存在下一层级的数据,因此,该同步任务不存在下一层级的同步任务。所述员工客户数据为该员工所跟进的客户的详细信息,例如,客户微信号、客户名称、该员工与该客户的聊天记录等等。
96.服务节点接收到kafka平台分发的获取客户群数据的同步任务后,调用企业微信接口分页批量获取该员工管理的客户群的群列表信息,更新群列表信息至本地库。例如员工a管理了10个群,分别是一号群、二号群、三号群、四号群、五号群、六号群、七号群、八号群、九号群、十号群;即更新群列表信息一号群、二号群、三号群、四号群、五号群、六号群、七号群、八号群、九号群、十号群至本地库。
97.这里,服务节点接收到群列表信息后,判断群列表信息下存在下一层级的数据,因此,该服务节点遍历员工的客户群id列表,将客户群id作为消息发送至kafka,kafka向各个服务节点分发获取单个客户群详情的同步任务;接收到获取单个客户群详情的同步任务的服务节点,服务调用企业微信接口获取该客户群id对应的客户群详情,更新客户群详情数据至本地库。
98.至此,企业微信的全量数据同步完成。
99.请参照图3,图3示出了本技术实施例所述企业微信的全量数据同步的流程示意图。具体的,如图3所示,第一个服务节点接收到终端发送的全量数据更新请求,全量数据更新开始;第一个服务节点调用企业微信接口拉取企微后台的该企业的组织架构,并更新该企业的组织架构;该企业的组织架构为第一层级目标数据,根据组织架构中的各个部门id,将获取单个部门员工列表的同步任务分发至各个服务节点,每个服务节点接收到获取该部门id对应的员工列表的同步任务后,调用企业微信接口拉取该部门下的员工列表信息(一个部门拉取一次员工列表信息);每个部门的员工列表作为第二层级目标信息,根据每个部门的员工id,将获取每个员工id下的员工详情的同步任务、获取每个员工id下的客户数据的同步任务、获取每个员工id下的客户群列表的同步任务,分别分发至每个服务节点;服务节点接收到分发的获取员工详情的同步任务后,调用企业微信接口获取员工详情信息;服务节点接收到分发的获取员工客户数据的同步任务后,调用企业微信接口获取员工客户数据;服务节点接收到分发的获取客户群列表的同步任务后,调用企业微信接口分页批量获取该员工管理的客户群的群列表信息;这里,群列表信息作为第三层级目标信息,根据客户群id,将获取单个客户群详情的同步任务分发至各个服务节点,接收到获取单个客户群详情的同步任务的服务节点,服务调用企业微信接口获取该客户群id对应的客户群详情(按照一个群获取一次)。
100.在当前技术方案中,在进行全量数据同步的过程中,增量事件仍然可以被触发,那么数据在更新的过程中,就有可能会互相干扰,导致最终数据准确性受到影响。
101.基于此,请参照图4,本技术实施例中,所述的数据同步方法,还包括以下步骤:
102.s401、所述同步平台响应接收到全量数据更新请求,创建全量更新锁,以在所述全量更新锁存在时,停止处理接收到的增量数据更新事件;
103.s402、所述同步平台响应目标数据同步完成,释放所述全量更新锁,以开始处理在
全量数据同步期间接收到的增量数据更新事件。
104.在所述步骤s402中,以企业微信为例,所述目标数据同步完成,即最低层级目标数据-客户群详情更新完成。
105.当同步平台检测到全量数据更新已经完成后,释放全量更新锁,重启增量更新;每个服务节点分页获取本地库中状态为未执行的增量数据更新事件,并对未执行的增量数据更新事件进行补偿。
106.具体的,本技术实施例所述数据同步方法中,所述同步平台响应目标数据同步完成,释放所述全量更新锁,以开始处理在全量数据同步期间接收到的增量数据更新事件,包括:
107.响应释放所述全量更新锁,同步平台的每个服务节点根据记录的增量数据更新事件的状态标识,确定该服务节点中处于未处理状态增量数据更新事件;其中,所述状态标识是根据该服务节点接收到增量数据更新事件时,根据是否存在全量更新锁为所述增量数据更新事件添加的;
108.所述每个服务节点获取目标服务器中增量数据更新事件对应的数据,以完成全量数据同步期间的增量数据更新事件。
109.本技术实施例所述数据同步方法,通过引入全量同步锁,进行全量同步与增量同步之间的协调,在全量同步期间,停止增量同步的进行,并对全量同步期间的企业微信接口回调信息进行记录,在全量同步结束后,对全量同步期间积攒的事件进行重放,达到最终数据的一致,解决了现有方案中全量同步增量同步同时进行时可能会引发的数据不一致问题。
110.请参照图5,本技术实施例中,所述同步平台的服务节点接收到的增量数据更新事件,是通过以下方法获取的:
111.s501、所述同步平台的目标服务节点接收到目标服务器推送的增量数据更新事件;
112.s502、所述同步平台的目标服务节点根据接收到的增量数据更新事件发送至分发节点,以使所述分发节点将所述增量数据更新事件重新分发至同步平台中的任一服务节点,以使每个服务节点中的增量数据更新事件数量均衡。
113.这里,以企业微信和kafka为例,增量数据所针对的信息不同,增量数据更新事件类型不同;示例性的,增量数据更新事件包括:员工详情变动事件、客户数据变动事件、客户群详情变动事件;每种类型的增量数据更新时间,对应kafka中不同的消息队列。
114.目标服务节点接收到企业微信推送的增量数据更新事件后,记录更新事件原始报文至本地库,并解析事件类型为员工详情变动事件、客户数据变动事件、客户群详情变动事件,并将增量数据更新时间发送至对应类型的kafka队列中。
115.kafka将队列中的增量数据更新事件分发至各个服务节点;各个服务节点获取对应的增量数据事件后,若该服务节点判断当前存在全量同步锁,标记增量数据事件状态为undo,记录至本地库,不处理该增量数据事件;若该服务节点判断当前不存在全量同步锁,标记增量数据事件状态为doing,处理该增量数据事件;若该服务节点处理增量数据更新事件成功,标记该增量数据更新事件状态为done。
116.kafka将队列中的增量数据更新事件分发至各个服务节点,要保证每个服务节点
中的增量数据更新事件数量均衡,以增加增量数据更新事件的处理效率。
117.本技术实施例所述数据同步方案,在与企业微信之外的其他第三方平台进行数据对接时,如遇到类似的场景,同样可以采用本技术实施例所述数据同步方法的流程,只需要将其中任务细分以及数据处理部分进行替换即可。
118.其中,类似的场景为:所述全量数据同步时的目标数据中包括多个层级的数据,且根据上一层级的数据中的数据标识,能够划分出下一层级数据的同步块。
119.例如,当要实现钉钉中的全量数据同步时,可以按照以下策略划分任务,实现任务细分,划分出各个层级粒度的数据块:全量数据更新开始后,更新企业的架构,再按照部门id将一个部门的员工列表信息划分一个数据块;获取员工列表后,按照员工id,将每个员工详情划分为一个数据块;将每个员工所管理的群划分为一个数据块。
120.请参照图6,本技术实施例还提供一种数据同步装置,应用于同步平台,所述同步平台包括分发节点和多个服务节点;所述装置包括:
121.第一获取模块601,用于在所述多个服务节点中的任一服务节点在接收到针对目标数据的同步触发信息后,根据所述同步触发信息的类型,确定待同步的当前层级数据标识,并从所述目标数据所在目标服务器中获取所述当前层级数据标识对应的当前层级目标数据;
122.发送模块602,用于使获取到当前层级目标数据的服务节点根据所述当前层级目标数据,确定所述当前层级数据标识的下一级数据标识,并将所述下一级数据标识发送给所述分发节点;
123.分发模块603,用于使所述分发节点根据所述下一级数据标识确定同步任务,并将所述同步任务分发至所述多个服务节点;
124.第二获取模块604,用于使所述多个服务节点根据接收到的同步任务确定下一级数据标识,从所述目标服务器中获取所述下一级数据标识对应的下一级目标数据,以将所述目标服务器中的下一级目标数据同步到所述服务节点中。
125.本技术实施例提供一种数据同步装置,将全量同步任务进行拆分,拆分为多个细粒度的同步块,并分发到集群中的多个服务节点上,通过事件分发的方式对同步任务进行分治,使得多个服务节点同时进行数据全量同步任务,让整个集群能够协同完成全量同步任务,解决了现有方案中同步任务只能由单台节点完成的问题,合理的利用有限的资源,加快了全量数据同步的速度。
126.在一些实施例中,所述第一获取模块,在根据所述同步触发信息的类型,确定待同步的当前层级数据标识时,具体用于:
127.当所述同步触发信息为终端发送的全量数据更新请求时,根据预先配置的目标数据的数据层级结构,确定待同步的当前层级数据标识;
128.当所述同步触发信息为分发节点发送的同步任务时,从所述同步任务中提取出待同步的当前层级数据标识。
129.在一些实施例中,所述发送模块,在将所述下一级数据标识发送给所述分发节点时,当下一级数据标识对应多种类型的下一级目标数据时,具体用于:将所述下一级数据标识分别发送至所述分发节点的预先配置的对应类型的消息队列中;
130.相应的,所述分发模块,在使所述分发节点根据所述下一级数据标识确定同步任
务,并将所述同步任务分发至所述多个服务节点时,具体用于:
131.使所述分发节点根据每种类型的消息队列,确定每种类型的同步任务,并根据同步任务生成的顺序依次将每种类型的同步任务分发至服务节点。
132.在一些实施例中,所述的数据同步装置,还包括:
133.创造模块,用于在所述同步平台响应接收到全量数据更新请求,创建全量更新锁,以在所述全量更新锁存在时,停止处理接收到的增量数据更新事件;
134.释放模块,用于在所述同步平台响应目标数据同步完成,释放所述全量更新锁,以开始处理在全量数据同步期间接收到的增量数据更新事件。
135.所述数据同步装置,在全量数据同步开始时,设置全量同步锁,停止对增量数据同步的处理,并在全量数据同步结束后,通过对企业微信的接口回调进行梳理,提供了回放历史事件,准确更新增量数据的能力,保证了全量同步与增量同步的数据准确性。
136.在一些实施例中,所述释放模块,在所述同步平台响应目标数据同步完成,释放所述全量更新锁,以开始处理在全量数据同步期间接收到的增量数据更新事件时,具体用于:
137.响应释放所述全量更新锁,同步平台的每个服务节点根据记录的增量数据更新事件的状态标识,确定该服务节点中处于未处理状态增量数据更新事件;其中,所述状态标识是根据该服务节点接收到增量数据更新事件时,根据是否存在全量更新锁为所述增量数据更新事件添加的;
138.所述每个服务节点获取目标服务器中增量数据更新事件对应的数据,以完成全量数据同步期间的增量数据更新事件。
139.在一些实施例中,所述数据同步装置,还包括:
140.接收模块,具体用于使所述同步平台的服务节点接收到的增量数据更新事件;具体的,用于使所述同步平台的目标服务节点接收到目标服务器推送的增量数据更新事件;
141.所述同步平台的目标服务节点根据接收到的增量数据更新事件发送至分发节点,以使所述分发节点将所述增量数据更新事件重新分发至同步平台中的任一服务节点,以使每个服务节点中的增量数据更新事件数量均衡。
142.在一些实施例中,所述数据同步装置所要同步的所述目标数据为业务管理平台的目标服务器中储存的、目标企业的目标数据。
143.请参照图7,本技术实施例还提供一种电子设备700,包括:处理器702、存储器701和总线,所述存储器701存储有所述处理器702可执行的机器可读指令,当电子设备700运行时,所述处理器702与所述存储器701之间通过总线通信,所述机器可读指令被所述处理器702执行时执行所述的数据同步方法的步骤。
144.本技术实施例还提供一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,该计算机程序被处理器运行时执行所述的数据同步方法的步骤。
145.所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统和装置的具体工作过程,可以参考方法实施例中的对应过程,本技术中不再赘述。在本技术所提供的几个实施例中,应该理解到,所揭露的系统、装置和方法,可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,又例如,多个模块或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦
合或直接耦合或通信连接可以是通过一些通信接口,装置或模块的间接耦合或通信连接,可以是电性,机械或其它的形式。
146.所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
147.另外,在本技术各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。
148.所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个处理器可执行的非易失的计算机可读取存储介质中。基于这样的理解,本技术的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,平台服务器,或者网络设备等)执行本技术各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:u盘、移动硬盘、rom、ram、磁碟或者光盘等各种可以存储程序代码的介质。
149.以上仅为本技术的具体实施方式,但本技术的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本技术揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本技术的保护范围之内。因此,本技术的保护范围应以权利要求的保护范围为准。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1