CN109104501A - 一种数据同步方法、装置及系统 - Google Patents

一种数据同步方法、装置及系统 Download PDF

Info

Publication number
CN109104501A
CN109104501A CN201811161120.4A CN201811161120A CN109104501A CN 109104501 A CN109104501 A CN 109104501A CN 201811161120 A CN201811161120 A CN 201811161120A CN 109104501 A CN109104501 A CN 109104501A
Authority
CN
China
Prior art keywords
data
synchronized
client
server
synchronization type
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201811161120.4A
Other languages
English (en)
Other versions
CN109104501B (zh
Inventor
纪纲
余雪亭
邓淼
徐毅刚
张云鹏
杨晨
绕涛
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Qihoo Technology Co Ltd
Original Assignee
Beijing Qihoo Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Qihoo Technology Co Ltd filed Critical Beijing Qihoo Technology Co Ltd
Priority to CN201811161120.4A priority Critical patent/CN109104501B/zh
Publication of CN109104501A publication Critical patent/CN109104501A/zh
Application granted granted Critical
Publication of CN109104501B publication Critical patent/CN109104501B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1095Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

本发明实施例提供的一种数据同步方法,该方法可应用于客户端中,方法包括:获取所述客户端中的待同步客户端数据;在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。通过本方法解决了现有技术数据同步中需要将整条完整的数据进行备份,存在数据重复备份、浪费流量资源的问题。

Description

一种数据同步方法、装置及系统
技术领域
本发明涉及数据同步技术领域,具体而言,涉及一种数据同步方法、装置及系统。
背景技术
人们的工作与生活资料越来越多的记录在手机、平板、个人电脑等电子设备上,有些应用软件(客户端)会同时存在多个不同的平台版本,并安装在不同的设备上,而在不同设备上进行操作后就存在数据不同步的问题。
为了解决该问题,就需要将数据在不同的设备上实现同步,但目前的数据同步方法几乎停留在备份和还原的阶段,即当使用第一个平台的客户端将数据备份至服务器后,在使用另一个平台的客户端的时候通常需要将数据从服务器还原,实现多平台同步协同工作。该种数据同步方式,需要全量数据下载更新或上传备份,随着数据量的积累这种方法往往难以为继。
即现有技术存在的技术问题为,在数据同步的时候需要将整条完整的数据进行备份,存在数据重复,浪费流量和存储资源。
发明内容
有鉴于此,本发明实施例的目的在于提供一种数据同步方法、装置及系统,以解决现有技术数据同步中需要将整条完整的数据进行备份,存在数据重复备份、浪费流量资源的问题。
第一方面,本申请通过本申请的一实施例提供如下技术方案:
一种数据同步方法,应用于客户端中,包括:获取所述客户端中的待同步客户端数据;在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
优选地,所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,包括:根据所述第一同步类型标记,将所述待同步客户端数据保存为预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记;将所述预定义格式的待同步客户端数据发送给所述服务端。
优选地,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中字段的修改;附加标记,用于表示一条数据中的字段增加。
优选地,在所述第一同步类型标记为所述删除标记时,所述在所述待同步客户端数据中添加第一同步类型标记之后,还包括:对所述待同步客户端数据进行逻辑删除;在接收到所述服务端反馈的表示同步成功的同步状态信息时,对所述待同步客户端数据进行物理删除,所述同步成功的同步状态信息用于表示所述待同步客户端数据已成功同步至所述服务端中。
优选地,在所述第一同步类型标记为所述增加标记时,在所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端之前,还包括:在所述待同步客户端数据中添加客户端识别信息,所述客户端识别信息用于唯一标识所述待同步客户端数据。
优选地,还包括:向所述服务端发送数据获取请求;接收所述服务端根据所述数据获取请求发送的待同步服务端数据,所述待同步服务端数据中携带有所述服务端添加的第二同步类型标记,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作;基于所述第二同步类型标记,对所述待同步服务端数据进行同步操作。
第二方面,本申请通过本申请的一实施例提供如下技术方案:
一种数据同步方法,应用于服务端中,包括:接收客户端发送的携带有第一同步类型标记的待同步客户端数据,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
优选地,所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据的步骤,包括:接收客户端发送的预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记。
优选地,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中的字段更新;附加标记,用于表示一条数据中的字段增加。
优选地,在所述第一同步类型标记为删除标记时,在接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,还包括:生成表示同步成功的同步状态信息,并将所述同步状态信息发送至客户端,以使所述客户端对已进行逻辑删除的所述待同步客户端数据进行物理删除。
优选地,在所述第一同步类型标记为增加标记时,在所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,还包括:为所述待同步客户端数据添加服务端识别信息,所述服务端识别信息与所述待同步客户端数据中的客户端识别信息唯一对应;其中,所述待同步客户端数据中包括客户端添加的客户端识别信息。
优选地,还包括:接收所述客户端发送的数据获取请求;根据所述数据获取请求,将携带有所述服务端添加的第二同步类型标记的待同步服务端数据发送给客户端,以使客户端根据所述第二同步类型标记,对所述待同步服务端数据进行同步操作;其中,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作。
第三方面,本申请通过本申请的一实施例提供如下技术方案:
一种客户端,包括:获取模块,用于获取所述客户端中的待同步客户端数据;标记模块,用于在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;第一发送模块,用于将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
优选地,所述第一发送模块包括:转化单元,用于根据所述第一同步类型标记,将所述待同步客户端数据保存为预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记;发送单元,用于将所述预定义格式的待同步客户端数据发送给所述服务端。
优选地,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中字段的修改;附加标记,用于表示一条数据中的字段增加。
优选地,还包括:逻辑删除模块,用于在所述第一同步类型标记为所述删除标记时,且在所述待同步客户端数据中添加第一同步类型标记之后,对所述待同步客户端数据进行逻辑删除;物理删除模块,用于在所述第一同步类型标记为所述删除标记时,且在所述待同步客户端数据中添加第一同步类型标记之后,在接收到所述服务端反馈的表示同步成功的同步状态信息时,对所述待同步客户端数据进行物理删除,所述同步成功的同步状态信息用于表示所述待同步客户端数据已成功同步至所述服务端中。
优选地,还包括:第一识别信息添加模块,用于在所述第一同步类型标记为所述增加标记时,且在所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端之前,在所述待同步客户端数据中添加客户端识别信息,所述客户端识别信息用于唯一标识所述待同步客户端数据。
优选地,还包括:请求模块,用于向所述服务端发送数据获取请求;第一接收模块,用于接收所述服务端根据所述数据获取请求发送的待同步服务端数据,所述待同步服务端数据中携带有所述服务端添加的第二同步类型标记,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作;
第一同步模块,用于基于所述第二同步类型标记,对所述待同步服务端数据进行同步操作。
第四方面,本申请通过本申请的一实施例提供如下技术方案:
一种服务端,包括:第二接收模块,用于接收客户端发送的携带有第一同步类型标记的待同步客户端数据,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;第二同步模块,用于根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
优选地,所述第二接收模块具体用于接收客户端发送的预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记。
优选地,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中的字段更新;附加标记,用于表示一条数据中的字段增加。
优选地,还包括:反馈模块,用于在所述第一同步类型标记为删除标记时,且在接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,生成表示同步成功的同步状态信息,并将所述同步状态信息发送至客户端,以使所述客户端对已进行逻辑删除的所述待同步客户端数据进行物理删除。
优选地,还包括:第二识别信息添加模块,用于在所述第一同步类型标记为增加标记时,且在所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,为所述待同步客户端数据添加服务端识别信息,所述服务端识别信息与所述待同步客户端数据中的客户端识别信息唯一对应;其中,所述待同步客户端数据中包括客户端添加的客户端识别信息。
优选地,还包括:第三接收模块,用于接收所述客户端发送的数据获取请求;第二发送模块,根据所述数据获取请求,将携带有所述服务端添加的第二同步类型标记的待同步服务端数据发送给客户端,以使客户端根据所述第二同步类型标记,对所述待同步服务端数据进行同步操作;其中,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作。
第五方面,本申请通过本申请的一实施例提供如下技术方案:
一种电子设备,包括处理器和存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述电子设备执行以上第一方面中所述方法的步骤。
第六方面,本申请通过本申请的一实施例提供如下技术方案:
一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现上述第一方面中所述方法的步骤。
第七方面,本申请通过本申请的一实施例提供如下技术方案:
一种电子设备,包括处理器和存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述电子设备执行以上第二方面中所述方法的步骤。
第八方面,本申请通过本申请的一实施例提供如下技术方案:
一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现上述第二方面中所述方法的步骤。
第九方面,本申请通过本申请的一实施例提供如下技术方案:
一种数据同步系统,包括:至少一个客户端和至少一个服务端,所述客户端为以上第一至第四方面所述的客户端,所述服务器为以上第一至第四方面所述的服务端。
本申请实施例中提供的一个或多个技术方案,至少具有如下技术效果或优点:
本发明实施例提供的一种数据同步方法,与现有技术相比,应用于客户端中时,通过获取客户端中的待同步客户端数据,并对该待同步客户端数据添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作。通过第一同步类型标记可以针对性的筛选出待同步客户端数据。然后将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。也就是说服务端进行同步操作的时候并不是将服务端中原有的数据进行覆盖,而是根据第一同步类型标记进行局部改动以达到同步目的。以此,可保证待同步客户端数据根据第一同步类型标记进行同步操作,避免了客户端中数据的整体上传备份,避免数据的重复同步,避免浪费流量和存储资源。
为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1为本发明第一实施例提供的数据同步方法的第一流程图;
图2为本发明第一实施例提供的数据同步方法的第二流程图;
图3为本发明第四实施例提供的客户端的功能模块图;
图4为本发明第五实施例提供的服务端的功能模块图;
图5为本发明第六实施例提供的数据同步系统的功能模块图;
图6为本发明第七实施例提供的示例性的用户终端的结构框图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
第一实施例
请参照图1,在本实施例中提供一种用于隐私保密的方法,该方法可应用于客户端及服务端中。其中,客户端可以是可移动终端,例如手机、平板电脑、笔记本电脑等;服务端可以是服务器,如数据库服务器,安装有数据管理软件的存储服务器等。另外,客户端也可以是安装在移动终端上的应用软件,例如,记账本客户端软件、银行客户端软件及日历软件等;服务端可以相关的服务器上安装的数据管理软件。本实施例中,客户端与服务器的交互可以为无线网络或有限网络的形式。
图1示出了本方法应用于客户端及服务器中的交互示意图。具体的该方法包括:
步骤S11:客户端获取所述客户端中的待同步客户端数据。
步骤S12:客户端在所述待同步客户端数据中添加第一同步类型标记。
步骤S13:客户端将携带有所述第一同步类型标记的待同步客户端数据发送给服务器。
步骤S14:服务端接收客户端发送的携带有第一同步类型标记的待同步客户端数据获取所述客户端中的待同步客户端数据。
步骤S15:服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
步骤S16:服务端生成表示同步成功的同步状态信息,并将所述同步状态信息发送至客户端。
在步骤S11中,待同步客户端数据包括,在客户端中用户输入的新的数据,用户改动过的数据,以及用户删除的数据,总得来说为发生过改变的数据。例如,该客户端为记账本应用时,具有以下的三条数据:
表1
序号 时间 类型 用途 金额
1 2018年6月10日 餐饮 早餐 5元
2 2018年6月11日 交通 停车费 15元
3 2018年6月12日 交通 罚款 100元
若对序号为1的数据进行了修改:
表2
序号 时间 类型 用途 金额
1 2018年6月10日 餐饮 午餐 10元
2 2018年6月11日 交通 停车费 15元
3 2018年6月12日 交通 罚款 100元
则序号为1的数据中经过改动的数据为待同步客户端数据,此外进行过删除、修改、增加等操作的数据均为待同步客户端数据,在此不再赘述。
表1和表2仅为本实施中的举例说明,其包含的数据类型、结构不对本发明的实际保护范围构成限制,后文亦如此。
在步骤S12中,第一同步类型标记用于表示所述待同步客户端数据所对应的同步类型。具体的第一同步类型标记可包括:
1、增加标记,用于表示一条数据的增加。例如,若在表1中增加了序号为4的一条数据,那么此时可对序号为4的这条数据标记上增加标记,当进行数据同步的时候就采用增加操作。若第一同步类型标记为该增加标记时,那么可包括步骤S121:所述第一同步类型标记为所述增加标记时,在所述待同步客户端数据中添加客户端识别信息。
在步骤S121中,说明该条待同步客户端数据为新的一条数据,那么可对该待同步客户端数据中添加客户端识别信息,所述客户端识别信息用于唯一标识所述待同步客户端数据。客户端识别信息可包括:客户端ID,数据在客户端中存在的位置,数据的唯一编号等。
2、删除标记,用于表示一条数据的删除。例如,若在表1中删除了序号为3的一条数据,那么此时可对序号为3的这条数据标记上删除标记,即可表示对该条待同步客户端数据进行了逻辑删除,当进行数据同步的时候就采用删除操作。
3、覆盖标记,用于表示一条数据的覆盖。例如,若在表1中对序号为2的这条数据进行了重写或添加了一条新的数据将序号为2的数据进行了覆盖,那么此时可对序号为2的这条数据标记上覆盖标记,当进行数据同步的时候就采用覆盖操作。
4、修改标记,用于表示一条数据中字段的修改。例如,若在表1中对序号为1的这条数据进行了修改(字段“用途”“金额”中的内容),那么此时可对序号为1的这条数据中进行了修改的部分标记上修改标记,当进行数据同步的时候就采用修改操作。
5、附加标记,用于表示一条数据中的字段增加。例如,若在表1中对序号为1的这条数据进行了字段添加的操作(如表3所示,添加了字段“备注”,内容为“借款”),那么此时可对序号为1的这条数据中所添加的字段标记上附加标记,当进行数据同步的时候就采用附加操作。
表3
在步骤S13中,将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。具体的可分为如下两步进行:
首先,根据所述第一同步类型标记,将所述待同步客户端数据保存为预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记。其中,所述预定义格式可包括三部分:
1、第一同步类型标记,若具有更多的同步操作,则可相应的增加第一同步类型标记的种类,当数据发送至服务端后,服务端会根据第一同步类型标记采用第一同步类型标记所对应的同步操作。即该部分用于指导服务采取对应的同步操作,避免服务端进行所有数据的覆盖备份(覆盖同步)。
2、参数部分,该部分用于记录待同步客户端数据同步时的参数信息,例如,同步时的时间戳,待同步客户端数据的条数,待同步客户端数据的页码等。
3、数据部分,该部分为待同步客户端数据的主体部分,即待同步客户端数据的实际同步操作的内容。具体的,该部分可使用json(JavaScript Object Notation,JS对象简谱)表示。不同的待同步客户端数据具有自己不同的json串。另外,还可通过key_value的形式代表待同步客户端数据的字段、数据。
然后,将所述预定义格式的待同步客户端数据发送给所述服务端。通过对待同步客户端数据表示为预定义格式的三个部分,并且预定义格式中包括了所述第一同步类型标记,在向服务端发送待同步客户端数据数据时,其中的待同步客户端数据并非客户端中所有的数据,其中待同步客户端数据仅仅是发生过操作的数据。例如,对某条数据仅仅修改了一个字段,那么进行数据同步的时候,就只需同步该修改过的一个字段,无需进行整条完整数据的上传。可节省流量资源,提高同步效率,同时还大大的提高了较差网络环境下的同步效率。
步骤S14,接收客户端发送的携带有第一同步类型标记的待同步客户端数据。其中,接收可以是被动的接收,也可以是主动发送提醒信息以提示用户进行数据同步。
步骤S15,根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。在步骤S15中,具体的同步操作包括:
1、当待同步客户端数据标记为增加标记的时候,服务端可直接进行数据的增加操作,即新增一条数据。同时由于该待同步客户端数据为新增数据,同时该新增数据中包含有客户端识别信息,为了建立服务端中的数据与客户端中的数据的对应关系,可对新增的数据分配服务端识别信息。即可包括步骤S151:所述第一同步类型标记为增加标记时,为所述待同步客户端数据添加服务端识别信息。
在步骤S151中,所述服务端识别信息中应当包括:服务端ID,还可包括数据在服务器中存储的位置,数据在服务器中的编号等。可通客户端ID与服务器ID建立两端数据的一一对应关系。该服务端ID与客户端ID均可保存在数据部分中。
2、当待同步客户端数据标记为删除标记时,服务端可直接定位到需要删除的数据,并对其进行删除操作。定位方式可以根据需要删除的待同步客户端数据中预先添加的服务端识别信息进行定位。
3、当待同步客户端数据标记为覆盖标记时,即该条数据中的所有字段均发生了修改,服务端可直接根据服务端识别信息定位到需要重写的那条数据(可为一条或多条,下同),然后将其重写为(或覆盖)待用户客户端数据。
4、当待同步客户端数据标记为修改标记时,说明该待同步客户端数据仅仅是一条数据中的某个字段内容的同步。不用同步整条数据,仅仅同步该条数据中发生过修改的字段,服务端根据修改标记在服务端定位到对应的那条数据后进行字段修改操作,实现更新,大大减小了同步的内容量。
5、当待同步客户端数据标记为附加标记时,说明该待同步客户端数据仅仅是一条数据中的增加了某个字段。此时,不用同步整条数据,服务端可仅将增加的字段同步增加到服务端中对应的那条数据中,例如增加到一条数据的末尾,或插入到一条数据的中间位置。
步骤S16,服务端生成表示同步成功的同步状态信息,并将所述同步状态信息发送至客户端。在步骤S16中,为了保证同步的有效性,服务端在完成同步操作后可生同步状态信息,反馈至客户端,以告知客户端“你的数据在我这边已经完成了同步操作”。相反的,若服务端的同步操作未完成,则可生产同步失败信息反馈到客户端,以提醒客户端再次同步。同步状态信息可为,一端可识别的编码/代号,可为一段指令等,可使客户端发出同步状态的提示。
在客户端接收到服务器发送的同步状态信息时,若该同步状态信息表示同步成功时,那么还可包括步骤S123:对已进行逻辑删除的所述待同步客户端数据进行物理删除。
在步骤S123中,若待同步客户端数据中不含删除标记时,则该步骤S123可不进行,若含有删除标记的则代表客户端中,含有进行过逻辑删除的待同步客户端数据,此时进行物理删除。通过该种方式,可以避免数据同步失败的时候丢失客户端中的待同步客户端数据。
请参照图2,在本发明实施例中,若有以下两种情况时,可将服务端数据完全同步到客户端上。
1、客户端为初次使用,即客户端中无原始数据。
2、当客户端为多个的时候。如,包括客户端A和客户端B,若客户端A中修改了数据导致,同步后服务端数据发生了改变;则需要对客户端B中的数据进行同步。同步时,以最近的修改时间为准,即距离当前最接近的时间。
对客户端B中的数据进行同步,具体包括步骤:
步骤S21:客户端向所述服务器发送数据获取请求。
步骤S22:服务器接收所述客户端发送的数据获取请求。
步骤S23:服务器根据所述数据获取请求,将携带有所述服务器添加的第二同步类型标记的待同步服务端数据发送给客户端。
在步骤S23中,所述的第二同步类型标记与所述第一同步类型标记的概念相同,即所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作,第二同步类型标记可包括:
增加标记,用于表示一条数据的增加。
删除标记,用于表示一条数据的删除。
覆盖标记,用于表示一条数据的覆盖。
修改标记,用于表示一条数据中字段的修改。
附加标记,用于表示一条数据中的字段增加。
待同步服务端数据表示在服务端相对于客户端发生过操作的数据。
步骤S24:客户端接收所述服务器根据所述数据获取请求发送的待同步服务端数据。
步骤S25:客户端基于所述第二同步类型标记,对所述待同步服务端数据进行同步操作。
在步骤S25中,同步操作的过程请参照步骤S15。
第二实施例
本发明还提供一种数据同步方法,该方法应用于客户端中,该客户端如第一实施例中所述。该数据同步方法包括:获取所述客户端中的待同步客户端数据;在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
可选的,所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,包括:根据所述第一同步类型标记,将所述待同步客户端数据保存为预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记;将所述预定义格式的待同步客户端数据发送给所述服务端。
可选的,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中字段的修改;附加标记,用于表示一条数据中的字段增加。
可选的,在所述第一同步类型标记为所述删除标记时,所述在所述待同步客户端数据中添加第一同步类型标记之后,还包括:对所述待同步客户端数据进行逻辑删除;在接收到所述服务端反馈的表示同步成功的同步状态信息时,对所述待同步客户端数据进行物理删除,所述同步成功的同步状态信息用于表示所述待同步客户端数据已成功同步至所述服务端中。
可选的,在所述第一同步类型标记为所述增加标记时,在所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端之前,还包括:在所述待同步客户端数据中添加客户端识别信息,所述客户端识别信息用于唯一标识所述待同步客户端数据。
可选的,所述方法还包括:向所述服务端发送数据获取请求;接收所述服务端根据所述数据获取请求发送的待同步服务端数据,所述待同步服务端数据中携带有所述服务端添加的第二同步类型标记,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作;基于所述第二同步类型标记,对所述待同步服务端数据进行同步操作。
第三实施例
在本实施例中还提供一种数据同步方法,应用于服务端中,所述服务端如第一实施例中所述,该数据同步方法包括:接收客户端发送的携带有第一同步类型标记的待同步客户端数据,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
可选的,所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据的步骤,包括:接收客户端发送的预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记。
可选的,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中的字段更新;附加标记,用于表示一条数据中的字段增加。
可选的,在所述第一同步类型标记为删除标记时,在接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,还包括:生成表示同步成功的同步状态信息,并将所述同步状态信息发送至客户端,以使所述客户端对已进行逻辑删除的所述待同步客户端数据进行物理删除。
可选的,在所述第一同步类型标记为增加标记时,在所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,还包括:为所述待同步客户端数据添加服务端识别信息,所述服务端识别信息与所述待同步客户端数据中的客户端识别信息唯一对应;其中,所述待同步客户端数据中包括客户端添加的客户端识别信息。
可选的,还包括:接收所述客户端发送的数据获取请求;根据所述数据获取请求,将携带有所述服务端添加的第二同步类型标记的待同步服务端数据发送给客户端,以使客户端根据所述第二同步类型标记,对所述待同步服务端数据进行同步操作;其中,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作。
综上,本发明实施例通过获取客户端中的待同步客户端数据,并对该待同步客户端数据添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作。通过第一同步类型标记可以针对性的筛选出待同步客户端数据。然后将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。也就是说服务端进行同步操作的时候并不是将服务端中原有的数据进行覆盖,而是根据第一同步类型标记进行局部改动以达到同步目的。以此,可保证待同步客户端数据根据第一同步类型标记进行同步操作,避免了客户端中数据的整体上传备份,避免数据的重复同步,避免浪费流量和存储资源。
第四实施例
基于同一发明构思在本实施例中还提供一种客户端,请参照图3,所述客户端包括:获取模块601、标记模块602和第一发送模块603。其中:
获取模块601,用于获取所述客户端中的待同步客户端数据;
标记模块602,用于在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;
第一发送模块603,用于将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
优选地,所述第一发送模块603包括:
转化单元,用于根据所述第一同步类型标记,将所述待同步客户端数据保存为预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记;
发送单元,用于将所述预定义格式的待同步客户端数据发送给所述服务端。
优选地,所述第一同步类型标记,包括:
增加标记,用于表示一条数据的增加;
删除标记,用于表示一条数据的删除;
覆盖标记,用于表示一条数据的覆盖;
修改标记,用于表示一条数据中字段的修改;
附加标记,用于表示一条数据中的字段增加。
优选地,还包括:
逻辑删除模块,用于在所述第一同步类型标记为所述删除标记时,且在所述待同步客户端数据中添加第一同步类型标记之后,对所述待同步客户端数据进行逻辑删除;
物理删除模块,用于在所述第一同步类型标记为所述删除标记时,且在所述待同步客户端数据中添加第一同步类型标记之后,在接收到所述服务端反馈的表示同步成功的同步状态信息时,对所述待同步客户端数据进行物理删除,所述同步成功的同步状态信息用于表示所述待同步客户端数据已成功同步至所述服务端中。
优选地,还包括:
第一识别信息添加模块,用于在所述第一同步类型标记为所述增加标记时,且在所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端之前,在所述待同步客户端数据中添加客户端识别信息,所述客户端识别信息用于唯一标识所述待同步客户端数据。
优选地,还包括:
请求模块,用于向所述服务端发送数据获取请求;
第一接收模块,用于接收所述服务端根据所述数据获取请求发送的待同步服务端数据,所述待同步服务端数据中携带有所述服务端添加的第二同步类型标记,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作;
第一同步模块,用于基于所述第二同步类型标记,对所述待同步服务端数据进行同步操作。
第五实施例
基于同一发明构思,在本实施例中还提供一种服务端,请参阅图4,所述服务端包括:第二接收模块701和第二同步模块702。其中:
第二接收模块701,用于接收客户端发送的携带有第一同步类型标记的待同步客户端数据,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;
第二同步模块702,用于根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
优选地,所述第二接收模块701具体用于接收客户端发送的预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记。
优选地,所述第一同步类型标记,包括:
增加标记,用于表示一条数据的增加;
删除标记,用于表示一条数据的删除;
覆盖标记,用于表示一条数据的覆盖;
修改标记,用于表示一条数据中的字段更新;
附加标记,用于表示一条数据中的字段增加。
优选地,还包括:
反馈模块,用于在所述第一同步类型标记为删除标记时,且在接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,生成表示同步成功的同步状态信息,并将所述同步状态信息发送至客户端,以使所述客户端对已进行逻辑删除的所述待同步客户端数据进行物理删除。
优选地,还包括:
第二识别信息添加模块,用于在所述第一同步类型标记为增加标记时,且在所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,为所述待同步客户端数据添加服务端识别信息,所述服务端识别信息与所述待同步客户端数据中的客户端识别信息唯一对应;
其中,所述待同步客户端数据中包括客户端添加的客户端识别信息。
优选地,还包括:
第三接收模块,用于接收所述客户端发送的数据获取请求;
第二发送模块,根据所述数据获取请求,将携带有所述服务端添加的第二同步类型标记的待同步服务端数据发送给客户端,以使客户端根据所述第二同步类型标记,对所述待同步服务端数据进行同步操作;
其中,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作。
第六实施例
基于同一发明构思,在本实施例中还提供一种数据同步系统,请参阅图5,所述数据同步系统包括:至少一个客户端和至少一个服务端,所述客户端为第一实施例至第五实施例中所述的客户端,所述服务器为第一实施例至第五实施例中所述的服务端。
第七实施例
基于同一发明构思,在本实施例中还提供一种电子设备,包括处理器和存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述电子设备执行以上第一实施例至第三实施例中任一实施例所述方法的步骤。
关于上述实施例中的客户端及服务端以及系统,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
于本发明实施例中,提供一种用户终端,该用户终端中安装有操作系统以及第三方应用程序。用户终端可以为平板电脑、手机、笔记本电脑、PC(personal computer,个人计算机)、可穿戴设备、车载终端等用户终端设备。
图6示出了一种示例性用户终端500的模块框图。如图6所示,用户终端500包括存储器502、存储控制器504,一个或多个(图中仅示出一个)处理器506、外设接口508、网络模块510、输入输出模块512、显示模块514等。这些组件通过一条或多条通讯总线/信号线516相互通讯。
存储器502可用于存储软件程序以及模块,如本发明实施例中的数据同步方法、装置及系统(装置为客户端或服务端)对应的程序指令/模块,处理器506通过运行存储在存储器502内的软件程序以及模块,从而执行各种功能应用以及数据处理,如本发明实施例提供的数据同步方法。
存储器502可包括高速随机存储器,还可包括非易失性存储器,如一个或者多个磁性存储装置、闪存、或者其他非易失性固态存储器。处理器506以及其他可能的组件对存储器502的访问可在存储控制器504的控制下进行。
外设接口508将各种输入/输出装置耦合至处理器506以及存储器502。在一些实施例中,外设接口508,处理器506以及存储控制器504可以在单个芯片中实现。在其他一些实例中,他们可以分别由独立的芯片实现。
网络模块510用于接收以及发送网络信号。上述网络信号可包括无线信号或者有线信号。
输入输出模块512用于提供给用户输入数据实现用户与用户终端的交互。所述输入输出模块512可以是,但不限于,鼠标、键盘和触控屏幕等。
显示模块514在用户终端500与用户之间提供一个交互界面(例如用户操作界面)或用于显示图像数据给用户参考。在本实施例中,所述显示模块514可以是液晶显示器或触控显示器。若为触控显示器,其可为支持单点和多点触控操作的电容式触控屏或电阻式触控屏等。支持单点和多点触控操作是指触控显示器能感应到来自该触控显示器上一个或多个位置处同时产生的触控操作,并将该感应到的触控操作交由处理器进行计算和处理。
可以理解,图6所示的结构仅为示意,用户终端500还可包括比图6中所示更多或者更少的组件,或者具有与图6所示不同的配置。图6中所示的各组件可以采用硬件、软件或其组合实现。
本发明第八实施例提供了一种计算机存储介质,本发明第四实施例至第五实施例中的客户端、服务端及系统集成的功能模块如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明实现上述第一实施例至第三实施例的数据同步方法方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、电载波信号、电信信号以及软件分发介质等。需要说明的是,所述计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括电载波信号和电信信号。
在此提供的算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的网关、代理服务器、系统中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。
本发明公开了,A1.一种数据同步方法,其特征在于,应用于客户端中,包括:获取所述客户端中的待同步客户端数据;在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
A2.如A1所述的数据同步方法,其特征在于,所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,包括:根据所述第一同步类型标记,将所述待同步客户端数据保存为预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记;将所述预定义格式的待同步客户端数据发送给所述服务端。
A3.如A1所述的方法,其特征在于,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中字段的修改;附加标记,用于表示一条数据中的字段增加。
A4.如A3所述的数据同步方法,其特征在于,在所述第一同步类型标记为所述删除标记时,所述在所述待同步客户端数据中添加第一同步类型标记之后,还包括:对所述待同步客户端数据进行逻辑删除;在接收到所述服务端反馈的表示同步成功的同步状态信息时,对所述待同步客户端数据进行物理删除,所述同步成功的同步状态信息用于表示所述待同步客户端数据已成功同步至所述服务端中。
A5.如A3所述的方法,其特征在于,在所述第一同步类型标记为所述增加标记时,在所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端之前,还包括:在所述待同步客户端数据中添加客户端识别信息,所述客户端识别信息用于唯一标识所述待同步客户端数据。
A6.如A1所述的数据同步方法,其特征在于,还包括:向所述服务端发送数据获取请求;接收所述服务端根据所述数据获取请求发送的待同步服务端数据,所述待同步服务端数据中携带有所述服务端添加的第二同步类型标记,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作;基于所述第二同步类型标记,对所述待同步服务端数据进行同步操作。
B7.一种数据同步方法,其特征在于,应用于服务端中,包括:接收客户端发送的携带有第一同步类型标记的待同步客户端数据,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
B8.如B7所述的数据同步方法,其特征在于,所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据的步骤,包括:接收客户端发送的预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记。
B9.如B 7所述的数据同步方法,其特征在于,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中的字段更新;附加标记,用于表示一条数据中的字段增加。
B10.如B 9所述的数据同步方法,其特征在于,在所述第一同步类型标记为删除标记时,在接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,还包括:生成表示同步成功的同步状态信息,并将所述同步状态信息发送至客户端,以使所述客户端对已进行逻辑删除的所述待同步客户端数据进行物理删除。
B11.如B 9所述的数据同步方法,其特征在于,在所述第一同步类型标记为增加标记时,在所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,还包括:为所述待同步客户端数据添加服务端识别信息,所述服务端识别信息与所述待同步客户端数据中的客户端识别信息唯一对应;其中,所述待同步客户端数据中包括客户端添加的客户端识别信息。
B12.如B 7所述的数据同步方法,其特征在于,还包括:接收所述客户端发送的数据获取请求;根据所述数据获取请求,将携带有所述服务端添加的第二同步类型标记的待同步服务端数据发送给客户端,以使客户端根据所述第二同步类型标记,对所述待同步服务端数据进行同步操作;其中,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作。
C13.一种客户端,其特征在于,包括:获取模块,用于获取所述客户端中的待同步客户端数据;标记模块,用于在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;第一发送模块,用于将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
C14.如C13所述的客户端,其特征在于,所述第一发送模块包括:转化单元,用于根据所述第一同步类型标记,将所述待同步客户端数据保存为预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记;发送单元,用于将所述预定义格式的待同步客户端数据发送给所述服务端。
C15.如C 13所述的客户端,其特征在于,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中字段的修改;附加标记,用于表示一条数据中的字段增加。
C16.如C 15所述的客户端,其特征在于,还包括:逻辑删除模块,用于在所述第一同步类型标记为所述删除标记时,且在所述待同步客户端数据中添加第一同步类型标记之后,对所述待同步客户端数据进行逻辑删除;物理删除模块,用于在所述第一同步类型标记为所述删除标记时,且在所述待同步客户端数据中添加第一同步类型标记之后,在接收到所述服务端反馈的表示同步成功的同步状态信息时,对所述待同步客户端数据进行物理删除,所述同步成功的同步状态信息用于表示所述待同步客户端数据已成功同步至所述服务端中。
C17.如C 15所述的客户端,其特征在于,还包括:第一识别信息添加模块,用于在所述第一同步类型标记为所述增加标记时,且在所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端之前,在所述待同步客户端数据中添加客户端识别信息,所述客户端识别信息用于唯一标识所述待同步客户端数据。
C18.如C 13所述的客户端,其特征在于,还包括:请求模块,用于向所述服务端发送数据获取请求;第一接收模块,用于接收所述服务端根据所述数据获取请求发送的待同步服务端数据,所述待同步服务端数据中携带有所述服务端添加的第二同步类型标记,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作;第一同步模块,用于基于所述第二同步类型标记,对所述待同步服务端数据进行同步操作。
D19.一种服务端,其特征在于,包括:第二接收模块,用于接收客户端发送的携带有第一同步类型标记的待同步客户端数据,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;第二同步模块,用于根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
D20.如D19所述的服务端,其特征在于,所述第二接收模块具体用于接收客户端发送的预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记。
D21.如D 19所述的服务端,其特征在于,所述第一同步类型标记,包括:增加标记,用于表示一条数据的增加;删除标记,用于表示一条数据的删除;覆盖标记,用于表示一条数据的覆盖;修改标记,用于表示一条数据中的字段更新;附加标记,用于表示一条数据中的字段增加。
D22.如D 21所述的服务端,其特征在于,还包括:反馈模块,用于在所述第一同步类型标记为删除标记时,且在接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,生成表示同步成功的同步状态信息,并将所述同步状态信息发送至客户端,以使所述客户端对已进行逻辑删除的所述待同步客户端数据进行物理删除。
D23.如D 21所述的服务端,其特征在于,还包括:第二识别信息添加模块,用于在所述第一同步类型标记为增加标记时,且在所述接收客户端发送的携带有第一同步类型标记的待同步客户端数据之后,为所述待同步客户端数据添加服务端识别信息,所述服务端识别信息与所述待同步客户端数据中的客户端识别信息唯一对应;其中,所述待同步客户端数据中包括客户端添加的客户端识别信息。
D24.如D 19所述的服务端,其特征在于,还包括:第三接收模块,用于接收所述客户端发送的数据获取请求;第二发送模块,根据所述数据获取请求,将携带有所述服务端添加的第二同步类型标记的待同步服务端数据发送给客户端,以使客户端根据所述第二同步类型标记,对所述待同步服务端数据进行同步操作;其中,所述第二同步类型标记用于表示所述待同步服务端数据所对应的同步操作。
E25.一种电子设备,其特征在于,包括处理器和存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述电子设备执行A1-A6中任一项所述方法的步骤。
F26.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现A1-A6中任一项所述方法的步骤。
G27.一种电子设备,其特征在于,包括处理器和存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述电子设备执行B7-B12中任一项所述方法的步骤。
H28.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现B7-B12中任一项所述方法的步骤。
I29.一种数据同步系统,其特征在于,包括:至少一个客户端和至少一个服务端,所述客户端为C13-C18所述的客户端,所述服务器为D19-D24所述的服务端。

Claims (10)

1.一种数据同步方法,其特征在于,应用于客户端中,包括:
获取所述客户端中的待同步客户端数据;
在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;
将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
2.根据权利要求1所述的数据同步方法,其特征在于,所述将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,包括:
根据所述第一同步类型标记,将所述待同步客户端数据保存为预定义格式的待同步客户端数据,所述预定义格式的待同步客户端数据包括所述第一同步类型标记;
将所述预定义格式的待同步客户端数据发送给所述服务端。
3.一种数据同步方法,其特征在于,应用于服务端中,包括:
接收客户端发送的携带有第一同步类型标记的待同步客户端数据,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;
根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
4.一种客户端,其特征在于,包括:
获取模块,用于获取所述客户端中的待同步客户端数据;
标记模块,用于在所述待同步客户端数据中添加第一同步类型标记,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;
第一发送模块,用于将携带有所述第一同步类型标记的待同步客户端数据发送给服务端,以使得所述服务端根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
5.一种服务端,其特征在于,包括:
第二接收模块,用于接收客户端发送的携带有第一同步类型标记的待同步客户端数据,所述第一同步类型标记用于表示所述待同步客户端数据所对应的同步操作;
第二同步模块,用于根据所述第一同步类型标记,对所述待同步客户端数据进行同步操作。
6.一种电子设备,其特征在于,包括处理器和存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述电子设备执行权利要求1-2中任一项所述方法的步骤。
7.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现权利要求1-2中任一项所述方法的步骤。
8.一种电子设备,其特征在于,包括处理器和存储器,所述存储器耦接到所述处理器,所述存储器存储指令,当所述指令由所述处理器执行时使所述电子设备执行权利要求3所述的方法的步骤。
9.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现权利要求3所述的方法的步骤。
10.一种数据同步系统,其特征在于,包括:至少一个客户端和至少一个服务端,所述客户端为权利要求4所述的客户端,所述服务器为权利要求5所述的服务端。
CN201811161120.4A 2018-09-30 2018-09-30 一种数据同步方法、装置及系统 Active CN109104501B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811161120.4A CN109104501B (zh) 2018-09-30 2018-09-30 一种数据同步方法、装置及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811161120.4A CN109104501B (zh) 2018-09-30 2018-09-30 一种数据同步方法、装置及系统

Publications (2)

Publication Number Publication Date
CN109104501A true CN109104501A (zh) 2018-12-28
CN109104501B CN109104501B (zh) 2023-02-17

Family

ID=64868035

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811161120.4A Active CN109104501B (zh) 2018-09-30 2018-09-30 一种数据同步方法、装置及系统

Country Status (1)

Country Link
CN (1) CN109104501B (zh)

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7359920B1 (en) * 2001-04-18 2008-04-15 Intellisync Corporation Communication protocol for synchronization of personal information management databases
CN101447874A (zh) * 2008-12-25 2009-06-03 深圳华为通信技术有限公司 一种数据同步方法、客户端及服务器
CN101459503A (zh) * 2007-12-12 2009-06-17 华为技术有限公司 一种实现数据同步的方法和装置
US7685459B1 (en) * 2006-04-13 2010-03-23 Symantec Operating Corporation Parallel backup
CN104065752A (zh) * 2014-07-11 2014-09-24 上海百步电子科技股份有限公司 终端间数据同步方法
CN104484428A (zh) * 2014-12-18 2015-04-01 深圳市科漫达智能管理科技有限公司 一种数据同步的方法、装置及系统
US20150256504A1 (en) * 2014-03-06 2015-09-10 Dropbox, Inc. Distributed synchronization data in a message management service

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7359920B1 (en) * 2001-04-18 2008-04-15 Intellisync Corporation Communication protocol for synchronization of personal information management databases
US7685459B1 (en) * 2006-04-13 2010-03-23 Symantec Operating Corporation Parallel backup
CN101459503A (zh) * 2007-12-12 2009-06-17 华为技术有限公司 一种实现数据同步的方法和装置
CN101447874A (zh) * 2008-12-25 2009-06-03 深圳华为通信技术有限公司 一种数据同步方法、客户端及服务器
US20150256504A1 (en) * 2014-03-06 2015-09-10 Dropbox, Inc. Distributed synchronization data in a message management service
CN104065752A (zh) * 2014-07-11 2014-09-24 上海百步电子科技股份有限公司 终端间数据同步方法
CN104484428A (zh) * 2014-12-18 2015-04-01 深圳市科漫达智能管理科技有限公司 一种数据同步的方法、装置及系统

Also Published As

Publication number Publication date
CN109104501B (zh) 2023-02-17

Similar Documents

Publication Publication Date Title
CN110019279B (zh) 在线文档的协同更新方法、装置、设备及存储介质
CN109391509A (zh) 一种更新应用程序的方法、系统及应用服务器
US20140280463A1 (en) Implementing a consistent ordering of operations in collaborative editing of shared content items
CN108549673A (zh) 网页资源的预加载方法、客户端、服务器及网络系统
CN103491066B (zh) 页面显示的方法、系统、服务端设备及客户端设备
CN104115142B (zh) 用于书签同步的特定于设备的文件夹
CN103988200A (zh) 用于web应用的轻量化框架
CN107656748B (zh) 应用发布的方法和装置
CN108897543A (zh) 版本的临时编译系统、方法、装置及存储介质
CN109245908A (zh) 一种主从集群切换的方法和装置
CN108038153A (zh) Hbase的数据在线迁移方法和装置
CN107203629A (zh) 页面呈现方法、系统和装置
CN111881392A (zh) 展示页面的方法和装置
CN109710364A (zh) 调整布局方式的方法、装置、电子设备及存储介质
CN104094299B (zh) 从发布的日历检索可用性信息的方法和设备
CN108259942A (zh) 获取预览广告的方法、装置及系统
CN110019242A (zh) 用于数据表的处理方法、装置和系统
US20160021089A1 (en) Content delivery subscription
CN109918381A (zh) 用于存储数据的方法和装置
CN110046000A (zh) 小程序运行方法和装置
CN107391100B (zh) 一种支持多语言账单的配置文件生成方法及装置
CN109104501A (zh) 一种数据同步方法、装置及系统
CN109725913A (zh) 数据更新的方法和装置
CN108153845B (zh) 一种实现后台图像数据导出的方法及装置
CN111767495A (zh) 一种合成网页的方法及系统

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant