CN110365763B - 一种数据同步方法、装置、设备及存储介质 - Google Patents

一种数据同步方法、装置、设备及存储介质 Download PDF

Info

Publication number
CN110365763B
CN110365763B CN201910623968.2A CN201910623968A CN110365763B CN 110365763 B CN110365763 B CN 110365763B CN 201910623968 A CN201910623968 A CN 201910623968A CN 110365763 B CN110365763 B CN 110365763B
Authority
CN
China
Prior art keywords
data
signature
full
server
incremental
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.)
Active
Application number
CN201910623968.2A
Other languages
English (en)
Other versions
CN110365763A (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 Milaiwu Network Technology Co ltd
Original Assignee
Beijing Milaiwu Network 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 Milaiwu Network Technology Co ltd filed Critical Beijing Milaiwu Network Technology Co ltd
Priority to CN201910623968.2A priority Critical patent/CN110365763B/zh
Publication of CN110365763A publication Critical patent/CN110365763A/zh
Application granted granted Critical
Publication of CN110365763B publication Critical patent/CN110365763B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/64Protecting data integrity, e.g. using checksums, certificates or signatures
    • 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
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3247Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving digital signatures

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • General Health & Medical Sciences (AREA)
  • Bioethics (AREA)
  • Computer Hardware Design (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Health & Medical Sciences (AREA)
  • Hardware Redundancy (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明实施例公开了一种数据同步方法、装置、设备及存储介质。其中,该方法由设备执行,包括:获取服务器发送的数据同步指令,其中所述数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名;将所述增量数据存储到本地;将本地已有数据和所述增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名;根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失。本发明实施例通过将增量数据发送给设备,并比较服务器全量数据的数据标签和设备全量数据的数据标签,确定增量数据在传输时是否产生偏差,确保数据的同步传输。

Description

一种数据同步方法、装置、设备及存储介质
技术领域
本发明实施例涉及数据通信技术,尤其涉及一种数据同步方法、装置、设备及存储介质。
背景技术
服务器端通过长链服务向多个设备广播数据,但是可能由于网络的问题导致部分设备数据与服务器端不一致。
现有的解决方式是给所有设备发送全量的数据或者直接将增量数据发送给设备。但发送全量数据的方案在用户量很大的情况下,会浪费大量的流量,传输效率慢;直接发送增量数据的方案极有可能在传输过程中产生增量数据发生错误的情况,导致设备的数据与服务器端的数据不符,无法确保数据的同步传输。
发明内容
本发明实施例提供一种数据同步方法、装置、设备及存储介质,以实现数据的同步传输。
第一方面,本发明实施例提供了一种数据同步方法,由设备执行,该方法包括:
获取服务器发送的数据同步指令,其中所述数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名;
将所述增量数据存储到本地;
将本地已有数据和所述增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名;
根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失。
可选的,所述数据同步指令中还包括签名规则,所述第一数据签名是采用所述签名规则对服务器的全量数据进行处理得到的;
相应地,所述对本地的全量数据进行处理得到第二数据签名,包括:
采用所述签名规则,对所述本地的全量数据进行处理得到所述第二数据签名。
可选的,所述将本地已有数据和所述增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名,包括:
根据服务器标识信息,从本地预先存储的签名规则与服务器之间映射关系,确定服务器的签名规则;
采用确定的签名规则,对本地的全量数据进行处理,获得第二数据签名。
可选的,所述根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失之后,还包括:
若存在数据丢失,则向服务器发送全量数据同步请求,以指示服务器向设备发送全量数据;
将接收的全量数据存储到本地。
第二方面,本发明实施例还提供了一种数据同步方法,由服务器执行,该方法包括:
确定待同步的增量数据;
对服务器中的全量数据进行处理,得到第一数据签名;
生成数据同步指令,其中所述数据同步指令中包括待同步的增量数据和所述第一数据签名;
向设备发送所述数据同步指令,以指示设备执行如下:将所述增量数据存储到设备中;将设备中已有数据和所述增量数据作为设备的全量数据,并对设备的全量数据进行处理得到第二数据签名;根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失。
第三方面,本发明实施例还提供了一种数据同步装置,该装置配置于设备中,该装置包括:
数据同步指令获取模块,用于获取服务器发送的数据同步指令,其中所述数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名;
增量数据存储模块,用于将所述增量数据存储到本地;
本地全量数据处理模块,用于将本地已有数据和所述增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名;
数据丢失确定模块,用于根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失。
可选的,所述数据同步指令获取模块,具体用于:
所述数据同步指令中还包括签名规则,所述第一数据签名是采用所述签名规则对服务器的全量数据进行处理得到的;
相应的,所述本地全量数据处理模块,具体用于:
采用所述签名规则,对所述本地的全量数据进行处理得到所述第二数据签名。
可选的,所述本地全量数据处理模块,包括:
签名规则确定单元,用于根据服务器标识信息,从本地预先存储的签名规则与服务器之间映射关系,确定服务器的签名规则;
第二数据签名获得单元,用于采用确定的签名规则,对本地的全量数据进行处理,获得第二数据签名。
可选的,所述数据丢失确定模块,包括:
全量数据发送单元,用于若存在数据丢失,则向服务器发送全量数据同步请求,以指示服务器向设备发送全量数据;
全量数据存储单元,用于将接收的全量数据存储到本地。
第四方面,本发明实施例还提供了一种数据同步装置,该装置配置于服务器中,该装置包括:
增量数据确定模块,用于确定待同步的增量数据;
服务器全量数据处理模块,用于对服务器中的全量数据进行处理,得到第一数据签名;
数据同步指令生成模块,用于生成数据同步指令,其中所述数据同步指令中包括待同步的增量数据和所述第一数据签名;
数据同步指令发送模块,用于向设备发送所述数据同步指令,以指示设备执行如下:将所述增量数据存储到设备中;将设备中已有数据和所述增量数据作为设备的全量数据,并对设备的全量数据进行处理得到第二数据签名;根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失。
第五方面,本发明实施例还提供了一种设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如本发明实施例一、二、四、六或八中任一所述的数据同步方法。
第六方面,本发明实施例还提供了一种服务器,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如本发明实施例三、五、七或九中任一所述的数据同步方法。
第七方面,本发明实施例还提供了一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行如本发明实施例一、二、四、六或八中任一所述的数据同步方法。
第八方面,本发明实施例还提供了一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行如本发明实施例三、五、七或九中任一所述的数据同步方法。
本发明实施例通过服务器采用签名规则得到服务器端全量数据的数据标签,在增量数据传送到设备时,通过签名规则确定设备中全量数据的数据标签,比较两个数据标签,确定增量数据在传输过程中是否存在数据丢失,以保证数据的同步传输。
附图说明
图1是本发明实施例一中的数据同步方法的流程示意图;
图2是本发明实施例二中的数据同步方法的流程示意图;
图3是本发明实施例三中的数据同步方法的流程示意图;
图4是本发明实施例四中的数据同步装置的结构框图;
图5是本发明实施例五中的数据同步装置的结构框图;
图6是本发明实施例六中的一种设备的结构示意图;
图7是本发明实施例七中的一种服务器的结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
实施例一
图1为本发明实施例一提供的一种数据同步方法的流程示意图,本实施例可适用于数据同步传输的情况,该方法可以由设备中的数据同步装置来执行,如图1所示,该方法具体包括如下步骤:
步骤110、获取服务器发送的数据同步指令,其中数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名。
其中,由设备获取服务器发出的数据同步指令,数据同步指令中包括待同步的增量数据、对服务器的全量数据进行处理得到的第一数据签名,也可以包括签名规则。第一数据签名是采用签名规则对服务器的全量数据进行处理所得到的该全量数据的唯一的数据签名,签名规则可以是根据服务器标识信息,从本地预先存储的签名规则与服务器之间的映射关系中,确定服务器的签名规则,也可以根据全量数据的内容及对增量后数据的要求,手动改变签名规则。例如,服务器当前的全量数据为数字1~100,服务器的签名规则是要求数据签名中标识出当前全量数据中数字的数量,因此可得第一数据签名为100;若只要求数据中的前十个数字保持不变,则可以将签名规则改为标识出当前全量数据中的前十个数字,可得第一数据签名为数字1~10。
步骤120、将增量数据存储到本地。
其中,将增量数据从服务器端传输到本地进行存储。
步骤130、将本地已有数据和增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名。
其中,将本地已有数据和增量数据合并为本地的全量数据,采用确定的签名规则,对本地的全量数据进行处理得到第二数据签名,本地已有数据为增量之前的全量数据。具体的,得到第一数据签名的签名规则和得到第二数据签名的签名规则相同,签名规则可以根据服务器与预先存储的签名规则之间的映射关系获取,也可以将签名规则附带在增量数据中,通过增量数据传输到本地。增量数据中同时附带第一数据签名,当得到第二数据签名时,将第一数据签名与第二数据签名进行比较。例如,第一数据标签为100,签名规则为标识出全量数据的数字数量,将签名规则和第一数据签名附带在增量数据上,在增量数据传输到本地后,将增量数据与本地已有数据合并,依据附带的签名规则确定本地全量数据的第二数据签名,若第二数据签名也是100,则同步后本地的全量数据与服务器的全量数据一致,增量数据在同步过程中没有发生变化,。
步骤140、根据第一数据签名和第二数据签名,确定是否存在数据丢失。
其中,比较第一数据签名与第二数据签名,若第一数据签名与第二数据签名一致,则说明增量同步过程成功,将同步过来的增量数据与本地已有数据合并为本地全量数据存储到本地;若第一数据签名与第二数据签名不一致,则说明增量数据的同步过程不成功,存在数据丢失,由设备向服务器发送全量数据同步请求,以指示服务器向设备发送全量数据,并由设备将接收到的全量数据存储到本地。例如,签名规则是标识出全量数据中数字的数量,第一数据签名为100,数据同步后第二数据签名为99,说明在增量数据同步的过程中,发生数据丢失现象,没有完整地将增量数据传输到本地,所以直接将服务器中全量数据的100个数字全部同步到本地中,从而完成数据同步;如果第一数据签名和第二数据签名都是100,则增量数据同步完成,结束数据同步的过程。
本实施例的技术方案,通过获取服务器发送的数据同步指令,将增量数据与第一数据签名同时发送到本地,将增量数据与本地已有数据结合得到本地全量数据,确定本地全量数据的第二数据签名,与第一数据签名比较,若一致,则说明在传输过程中数据没有丢失,解决了增量数据在同步过程中可能发生数据丢失,从而将错误的数据进行储存的现象,提高了数据同步的效率,确保数据存储的正确性,节省数据流量。
实施例二
图2为本发明实施例二提供的一种数据同步方法的流程示意图,本实施例以上述实施例为基础进行进一步的优化,该方法可以由设备中的数据同步装置来执行。如图2所示,该方法具体包括如下步骤:
步骤210、获取服务器发送的数据同步指令。
其中,由多个设备同时向服务器获取数据同步指令,数据同步指令中包括待同步的增量数据、对服务器的全量数据进行处理得到的第一数据签名以及签名规则。
步骤220、将增量数据存储到本地。
其中,增量数据要同时发送给多个设备,每个设备分别存储自己接收到的数据。
步骤230、将本地已有数据和增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名。
具体的,每一个设备都可以确定一个第二数据签名,将每一个第二数据签名分别于同一个第一数据签名做比较。
步骤240、根据第一数据签名和第二数据签名,确定是否存在数据丢失。
其中,在多个设备的第二数据签名与服务器的第一数据签名进行对比后,若有某设备的第二数据签名与第一数据签名不一致,则该设备的增量数据在同步过程中发生了数据丢失现象。
步骤250、将服务器的全量数据发送到存在数据丢失现象的设备。
其中,只需要将服务器全量数据发送给出现数据丢失现象的设备,若某设备的第二数据签名与第一数据签名相同,则不需要重新传输。
本实施例是将增量数据同时传输到多个设备,可以同时检测每个设备得到的增量数据是否正确,若不正确,只需向数据不正确的设备重新发送服务器的全量数据,保证了每个设备都能得到正确的数据,提高数据同步的效率,节省数据流量。
实施例三
图3为本发明实施例三提供的一种数据同步方法的流程示意图,本实施例可适用于数据同步传输的情况,该方法可以由服务器中的数据同步装置来执行,如图3所示,该方法具体包括如下步骤:
步骤310、确定待同步的增量数据。
其中,由服务器确定待同步的增量数据,同时确定本地设备的数量。
步骤320、对服务器中的全量数据进行处理,得到第一数据签名。
其中,采用签名规则,确定服务器中全量数据的第一数据签名,以对服务器的全量数据进行标识。
步骤330、生成数据同步指令,其中数据同步指令中包括待同步的增量数据和第一数据签名。
相应地,数据同步指令中可以包括签名规则,同时包括待同步的增量数据和第一数据签名。
步骤340、向设备发送数据同步指令,以指示设备执行如下:将增量数据存储到设备中;将设备中已有数据和增量数据作为设备的全量数据,并对设备的全量数据进行处理得到第二数据签名;根据第一数据签名和第二数据签名,确定是否存在数据丢失。
其中,由服务器向多个设备发送数据同步指令,每个设备接收服务器的增量数据,与本地已有的数据结合为本地的全量数据并存储在本地,依据签名规则确定本地全量数据的第二数据签名,将每个第二数据签名分别与第一数据签名作比较,若一致,则数据同步成功,结束同步过程;若不一致,则向数据签名不一致的设备发送服务器的全量数据,然后结束同步过程。
本发明实施例通过服务器向多个设备发送增量数据,比较第一数据签名和第二数据签名,检测本地全量数据与服务器全量数据是否一致,保证了数据同步的正确性,提高数据同步的效率,节省数据流量。
实施例四
图4是本发明实施例四所提供的数据同步装置的结构框图,可执行本发明实施例一或实施例二所提供的数据同步方法,具备执行方法相应的功能模块和有益效果。如图4所示,该装置包括:
数据同步指令获取模块401,用于获取服务器发送的数据同步指令,其中数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名;
增量数据存储模块402,用于将增量数据存储到本地;
本地全量数据处理模块403,用于将本地已有数据和增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名;
数据丢失确定模块404,用于根据第一数据签名和第二数据签名,确定是否存在数据丢失。
可选的,数据同步指令获取模块401,具体用于:
数据同步指令中还包括签名规则,第一数据签名是采用签名规则对服务器的全量数据进行处理得到的;
相应的,本地全量数据处理模块403,具体用于:
采用签名规则,对本地的全量数据进行处理得到第二数据签名。
可选的,本地全量数据处理模块403,包括:
签名规则确定单元,用于根据服务器标识信息,从本地预先存储的签名规则与服务器之间映射关系,确定服务器的签名规则;
第二数据签名获得单元,用于采用确定的签名规则,对本地的全量数据进行处理,获得第二数据签名。
可选的,数据丢失确定模块404,包括:
全量数据发送单元,用于若存在数据丢失,则向服务器发送全量数据同步请求,以指示服务器向设备发送全量数据;
全量数据存储单元,用于将接收的全量数据存储到本地。
本实施例提供一种数据同步装置,配置于设备中,通过检测服务器全量数据的第一数据签名与本地全量数据的第二数据签名是否一致,判断增量数据在同步过程中是否发生丢失现象,从而保证数据同步的正确性,提高数据同步的效率,节省传输流量。
实施例五
图5是本发明实施例五所提供的数据同步装置的结构框图,可执行本发明实施例三所提供的数据同步方法,具备执行方法相应的功能模块和有益效果。如图5所示,该装置包括:
增量数据确定模块501,用于确定待同步的增量数据;
服务器全量数据处理模块502,用于对服务器中的全量数据进行处理,得到第一数据签名;
数据同步指令生成模块503,用于生成数据同步指令,其中数据同步指令中包括待同步的增量数据和第一数据签名;
数据同步指令发送模块504,用于向设备发送数据同步指令,以指示设备执行如下:将增量数据存储到设备中;将设备中已有数据和增量数据作为设备的全量数据,并对设备的全量数据进行处理得到第二数据签名;根据第一数据签名和第二数据签名,确定是否存在数据丢失。
可选的,服务器全量数据处理模块502,具体用于:
采用签名规则,对服务器中的全量数据进行处理;
相应地,数据同步指令中包括签名规则。
本实施例提供一种数据同步装置,配置于服务器中,通过服务器向多个设备发送增量数据,比较第一数据签名和第二数据签名,检测本地全量数据与服务器全量数据的一致性,确定是否存在数据丢失,保证了数据同步的正确性,提高数据同步的效率,节省传输流量。
实施例六
图6是本发明实施例六提供的一种设备的结构示意图。图6示出了适于用来实现本发明实施例一、二或四的示例性设备600的框图。图6显示的设备600仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图6所示,设备600以通用计算设备的形式表现。设备600的组件可以包括但不限于:一个或者多个处理器或者处理单元601,系统存储器602,连接不同系统组件(包括系统存储器602和处理单元601)的总线603。
总线603表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器,外围总线,图形加速端口,处理器或者使用多种总线结构中的任意总线结构的局域总线。举例来说,这些体系结构包括但不限于工业标准体系结构(ISA)总线,微通道体系结构(MAC)总线,增强型ISA总线、视频电子标准协会(VESA)局域总线以及外围组件互连(PCI)总线。
设备600典型地包括多种计算机系统可读介质。这些介质可以是任何能够被设备600访问的可用介质,包括易失性和非易失性介质,可移动的和不可移动的介质。
系统存储器602可以包括易失性存储器形式的计算机系统可读介质,例如随机存取存储器(RAM)604和/或高速缓存存储器605。设备600可以进一步包括其它可移动/不可移动的、易失性/非易失性计算机系统存储介质。仅作为举例,存储系统606可以用于读写不可移动的、非易失性磁介质(图6未显示,通常称为“硬盘驱动器”)。尽管图6中未示出,可以提供用于对可移动非易失性磁盘(例如“软盘”)读写的磁盘驱动器,以及对可移动非易失性光盘(例如CD-ROM,DVD-ROM或者其它光介质)读写的光盘驱动器。在这些情况下,每个驱动器可以通过一个或者多个数据介质接口与总线603相连。存储器602可以包括至少一个程序产品,该程序产品具有一组(例如至少一个)程序模块,这些程序模块被配置以执行本发明实施例一、二或四的功能。
具有一组(至少一个)程序模块607的程序/实用工具608,可以存储在例如存储器602中,这样的程序模块607包括但不限于操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。程序模块607通常执行本发明所描述的实施例一、二或四中的功能和/或方法。
设备600也可以与一个或多个外部设备609(例如键盘、指向设备、显示器610等)通信,还可与一个或者多个使得用户能与该设备600交互的设备通信,和/或与使得该设备600能与一个或多个其它计算设备进行通信的任何设备(例如网卡,调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口611进行。并且,设备600还可以通过网络适配器612与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器612通过总线603与设备600的其它模块通信。应当明白,尽管图中未示出,可以结合设备600使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
处理单元601通过运行存储在系统存储器602中的程序,从而执行各种功能应用以及数据处理,例如实现本发明实施例一、二或四所提供的数据同步方法,包括:
获取服务器发送的数据同步指令,其中数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名;
将增量数据存储到本地;
将本地已有数据和增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名;
根据第一数据签名和第二数据签名,确定是否存在数据丢失。
实施例七
图7是本发明实施例七提供的一种服务器的结构示意图。图7示出了适于用来实现本发明实施例三或五的示例性服务器700的框图。图7显示的服务器700仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图7所示,服务器700以通用形式表现。服务器700的组件可以包括但不限于:一个或者多个处理器或者处理单元701,系统存储器702,连接不同系统组件(包括系统存储器702和处理单元701)的总线703。
总线703表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器、外围总线、图形加速端口、处理器或者使用多种总线结构中的任意总线结构的局域总线。举例来说,这些体系结构包括但不限于工业标准体系结构(ISA)总线,微通道体系结构(MAC)总线,增强型ISA总线、视频电子标准协会(VESA)局域总线以及外围组件互连(PCI)总线。
服务器700典型地包括多种计算机系统可读介质。这些介质可以是任何能够被服务器700访问的可用介质,包括易失性和非易失性介质,可移动的和不可移动的介质。
系统存储器702可以包括易失性存储器形式的计算机系统可读介质,例如随机存取存储器(RAM)704和/或高速缓存存储器705。服务器700可以进一步包括其它可移动/不可移动的、易失性/非易失性计算机系统存储介质。仅作为举例,存储系统706可以用于读写不可移动的、非易失性磁介质(图7未显示,通常称为“硬盘驱动器”)。尽管图7中未示出,可以提供用于对可移动非易失性磁盘(例如“软盘”)读写的磁盘驱动器,以及对可移动非易失性光盘(例如CD-ROM,DVD-ROM或者其它光介质)读写的光盘驱动器。在这些情况下,每个驱动器可以通过一个或者多个数据介质接口与总线703相连。存储器702可以包括至少一个程序产品,该程序产品具有一组(例如至少一个)程序模块,这些程序模块被配置以执行本发明实施例三或五的功能。
具有一组(至少一个)程序模块707的程序/实用工具708,可以存储在例如存储器702中,这样的程序模块707包括但不限于操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。程序模块707通常执行本发明所描述的实施例三或五的功能和/或方法。
服务器700也可以与一个或多个外部设备709(例如键盘、指向设备、显示器710等)通信,还可与一个或者多个使得用户能与该服务器700交互的设备通信,和/或与使得该服务器700能与一个或多个其它计算设备进行通信的任何设备(例如网卡,调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口711进行。并且,服务器700还可以通过网络适配器712与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器712通过总线703与服务器700的其它模块通信。应当明白,尽管图中未示出,可以结合服务器700使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
处理单元701通过运行存储在系统存储器702中的程序,从而执行各种功能应用以及数据处理,例如实现本发明实施例三或五所提供的数据同步方法,包括:
确定待同步的增量数据;
对服务器中的全量数据进行处理,得到第一数据签名;
生成数据同步指令,其中数据同步指令中包括待同步的增量数据和第一数据签名;
向设备发送数据同步指令,以指示设备执行如下:将增量数据存储到设备中;将设备中已有数据和增量数据作为设备的全量数据,并对设备的全量数据进行处理得到第二数据签名;根据第一数据签名和第二数据签名,确定是否存在数据丢失。
实施例八
本发明实施例八还提供一种包含计算机可执行指令的存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本发明实施例一、二、四或六所提供的数据同步方法,包括:
获取服务器发送的数据同步指令,其中数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名;
将增量数据存储到本地;
将本地已有数据和增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名;
根据第一数据签名和第二数据签名,确定是否存在数据丢失。
本发明实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
实施例九
本发明实施例九还提供一种包含计算机可执行指令的存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本发明实施例三、五或七所提供的数据同步方法,包括:
确定待同步的增量数据;
对服务器中的全量数据进行处理,得到第一数据签名;
生成数据同步指令,其中数据同步指令中包括待同步的增量数据和第一数据签名;
向设备发送数据同步指令,以指示设备执行如下:将增量数据存储到设备中;将设备中已有数据和增量数据作为设备的全量数据,并对设备的全量数据进行处理得到第二数据签名;根据第一数据签名和第二数据签名,确定是否存在数据丢失。
本发明实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。

Claims (9)

1.一种数据同步方法,其特征在于,由设备执行,所述方法包括:
获取服务器发送的数据同步指令,其中所述数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名;
将所述增量数据存储到本地;
将本地已有数据和所述增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名;
根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失;
若存在数据丢失,则由数据签名不一致的设备向服务器发送全量数据同步请求,以指示服务器向数据签名不一致的设备发送全量数据;
将接收的全量数据存储到本地。
2.根据权利要求1所述的方法,其特征在于,所述数据同步指令中还包括签名规则,所述第一数据签名是采用所述签名规则对服务器的全量数据进行处理得到的;
相应地,所述对本地的全量数据进行处理得到第二数据签名,包括:
采用所述签名规则,对所述本地的全量数据进行处理得到所述第二数据签名。
3.根据权利要求1所述的方法,其特征在于,所述将本地已有数据和所述增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名,包括:
根据服务器标识信息,从本地预先存储的签名规则与服务器之间映射关系,确定服务器的签名规则;
采用确定的签名规则,对本地的全量数据进行处理,获得第二数据签名。
4.一种数据同步方法,其特征在于,由服务器执行,所述方法包括:
确定待同步的增量数据;
对服务器中的全量数据进行处理,得到第一数据签名;
生成数据同步指令,其中所述数据同步指令中包括待同步的增量数据和所述第一数据签名;
向设备发送所述数据同步指令,以指示设备执行如下:将所述增量数据存储到设备中;将设备中已有数据和所述增量数据作为设备的全量数据,并对设备的全量数据进行处理得到第二数据签名;根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失;
若存在数据丢失,则向数据签名不一致的设备发送服务器的全量数据。
5.一种数据同步装置,其特征在于,所述装置配置于设备中,所述装置包括:
数据同步指令获取模块,用于获取服务器发送的数据同步指令,其中所述数据同步指令中包括待同步的增量数据,以及对服务器的全量数据进行处理得到的第一数据签名;
增量数据存储模块,用于将所述增量数据存储到本地;
本地全量数据处理模块,用于将本地已有数据和所述增量数据作为本地的全量数据,并对本地的全量数据进行处理得到第二数据签名;
数据丢失确定模块,用于根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失;
所述数据丢失确定模块,包括:
全量数据发送单元,用于若存在数据丢失,则由数据签名不一致的设备向服务器发送全量数据同步请求,以指示服务器向数据签名不一致的设备发送全量数据;
全量数据存储单元,用于将接收的全量数据存储到本地。
6.一种数据同步装置,其特征在于,所述装置配置于服务器中,所述装置包括:
增量数据确定模块,用于确定待同步的增量数据;
服务器全量数据处理模块,用于对服务器中的全量数据进行处理,得到第一数据签名;
数据同步指令生成模块,用于生成数据同步指令,其中所述数据同步指令中包括待同步的增量数据和所述第一数据签名;
数据同步指令发送模块,用于向设备发送所述数据同步指令,以指示设备执行如下:将所述增量数据存储到设备中;将设备中已有数据和所述增量数据作为设备的全量数据,并对设备的全量数据进行处理得到第二数据签名;根据所述第一数据签名和所述第二数据签名,确定是否存在数据丢失;
所述装置还用于若存在数据丢失,则向数据签名不一致的设备发送服务器的全量数据。
7.一种设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求1-3中任一所述的数据同步方法。
8.一种服务器,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求4所述的数据同步方法。
9.一种包含计算机可执行指令的存储介质,其特征在于,所述计算机可执行指令在由计算机处理器执行时用于执行如权利要求1-3中任一所述的数据同步方法;或者执行如权利要求4所述的数据同步方法。
CN201910623968.2A 2019-07-11 2019-07-11 一种数据同步方法、装置、设备及存储介质 Active CN110365763B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910623968.2A CN110365763B (zh) 2019-07-11 2019-07-11 一种数据同步方法、装置、设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910623968.2A CN110365763B (zh) 2019-07-11 2019-07-11 一种数据同步方法、装置、设备及存储介质

Publications (2)

Publication Number Publication Date
CN110365763A CN110365763A (zh) 2019-10-22
CN110365763B true CN110365763B (zh) 2021-11-23

Family

ID=68218846

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910623968.2A Active CN110365763B (zh) 2019-07-11 2019-07-11 一种数据同步方法、装置、设备及存储介质

Country Status (1)

Country Link
CN (1) CN110365763B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110995723A (zh) * 2019-12-11 2020-04-10 深圳物讯科技有限公司 一种跨公安边界大数据传输数据不丢失的方法

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103368975B (zh) * 2013-07-31 2016-04-06 飞天诚信科技股份有限公司 一种批量数据安全传输的方法及系统
CN103678494B (zh) * 2013-11-15 2018-09-11 北京奇虎科技有限公司 客户端同步服务端数据的方法及装置
CN107251477B (zh) * 2015-02-11 2021-01-12 维萨国际服务协会 用于安全地管理生物计量数据的系统和方法
CN107819795A (zh) * 2016-09-12 2018-03-20 北京金山云网络技术有限公司 一种dns主辅服务器数据同步方法、装置及系统
CN108573016A (zh) * 2017-12-25 2018-09-25 北京金山云网络技术有限公司 一种数据一致性检查方法、装置、设备和存储介质
CN108769212B (zh) * 2018-05-31 2023-04-07 康键信息技术(深圳)有限公司 数据同步方法、装置、计算机设备和存储介质

Also Published As

Publication number Publication date
CN110365763A (zh) 2019-10-22

Similar Documents

Publication Publication Date Title
US11509505B2 (en) Method and apparatus for operating smart network interface card
US9336001B2 (en) Dynamic instrumentation
CN110764945A (zh) 一种崩溃日志处理方法、装置、设备和存储介质
CN109101228B (zh) 应用程序的执行方法和装置
CN111796978B (zh) 一种接口检测方法、装置、系统、设备及存储介质
CN107404418B (zh) 互联网产品测试方法、装置、设备及存储介质
CN110287146B (zh) 应用下载的方法、设备和计算机存储介质
CN112560078A (zh) 区块链数据处理方法、装置、设备及介质
CN111818145B (zh) 一种文件传输方法、装置、系统、设备及存储介质
CN110659210A (zh) 一种信息获取方法、装置、电子设备及存储介质
CN109284108B (zh) 无人车数据存储方法、装置、电子设备及存储介质
CN110554929B (zh) 数据校验方法、装置、计算机设备及存储介质
CN109218393B (zh) 一种推送的实现方法、装置、设备和计算机存储介质
CN110990346A (zh) 基于区块链的文件数据处理方法、装置、设备及存储介质
CN112966824A (zh) 推理库的部署方法、装置和电子设备
CN110365763B (zh) 一种数据同步方法、装置、设备及存储介质
CN115391322A (zh) 数据检核方法、装置、设备、存储介质及程序产品
CN110134419B (zh) 一种双面柜的系统升级方法、装置、设备及存储介质
CN111679892A (zh) 分布式事务的处理方法、装置、设备及介质
CN107992457B (zh) 一种信息转换方法、装置、终端设备及存储介质
CN112685072B (zh) 通信地址知识库的生成方法、装置、设备及存储介质
CN112364268A (zh) 资源获取方法、装置、电子设备及存储介质
CN111741046B (zh) 数据上报方法、获取方法、装置、设备及介质
CN111262727B (zh) 服务的扩容方法、装置、设备及存储介质
CN113656301A (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