CN114385570A - 数据同步的方法、装置、电子设备和可读介质 - Google Patents

数据同步的方法、装置、电子设备和可读介质 Download PDF

Info

Publication number
CN114385570A
CN114385570A CN202111647526.5A CN202111647526A CN114385570A CN 114385570 A CN114385570 A CN 114385570A CN 202111647526 A CN202111647526 A CN 202111647526A CN 114385570 A CN114385570 A CN 114385570A
Authority
CN
China
Prior art keywords
file
information
local
synchronized
remote
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.)
Pending
Application number
CN202111647526.5A
Other languages
English (en)
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.)
Futuo Network Technology Shenzhen Co ltd
Original Assignee
Futuo Network Technology Shenzhen 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 Futuo Network Technology Shenzhen Co ltd filed Critical Futuo Network Technology Shenzhen Co ltd
Priority to CN202111647526.5A priority Critical patent/CN114385570A/zh
Publication of CN114385570A publication Critical patent/CN114385570A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/17Details of further file system functions
    • G06F16/178Techniques for file synchronisation in file systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/16File or folder operations, e.g. details of user interfaces specifically adapted to file systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/18File system types
    • G06F16/182Distributed file systems

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Information Transfer Between Computers (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本申请提供一种数据同步的方法、装置、电子设备和可读介质。该方法包括:获取各个远程文件的文件信息,文件信息包括版本信息;根据各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对各个本地文件的文件信息进行更新,得到各个更新文件;展示各个更新文件,并获取待同步文件选择消息,待同步文件选择消息中包括从各个更新文件中确定的待同步文件;根据待同步文件的版本信息,将待同步文件与远程文件进行同步。该方法可以仅同步要编辑的待同步文件的文件内容,从而降低草稿的数据同步过程的数据量,提升响应速度,进而能够避免同步过程阻塞用户操作,改善用户体验。

Description

数据同步的方法、装置、电子设备和可读介质
技术领域
本申请涉及计算机技术领域,尤其涉及一种数据同步的方法、装置、电子设备和可读介质。
背景技术
目前,随着云技术的发展,软件的各类本地功能都被转移到云端来进行。在各类内容发布平台中,草稿的编辑和保存等相关功能也被转移到云端来执行。
在相关技术中,用户在本地应用中编辑的草稿会被同步到云端中。当用户在其它的设备中登录时,则会从云端中获取到尚未完成的草稿来继续进行编辑。
然而,在上述方案中,草稿的数据同步过程需要将云端和本地应用中的草稿数据保持一致,需要传输和接收的数据量较大,容易造成同步过程阻塞用户操作,从而降低了响应速度,影响用户体验。
发明内容
基于上述技术问题,本申请提供一种数据同步的方法、装置、电子设备和可读介质,以可以仅同步要编辑的待同步文件的文件内容,从而降低草稿的数据同步过程的数据量,提升响应速度,进而能够避免同步过程阻塞用户操作,改善用户体验。
本申请的其他特性和优点将通过下面的详细描述变得显然,或部分地通过本申请的实践而习得。
根据本申请实施例的一个方面,提供一种数据同步的方法,包括:
获取各个远程文件的文件信息,所述文件信息包括版本信息;
根据所述各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对所述各个本地文件的文件信息进行更新,得到各个更新文件;
展示所述各个更新文件,并获取待同步文件选择消息,所述待同步文件选择消息中包括从所述各个更新文件中确定的待同步文件;
根据所述待同步文件的版本信息,将所述待同步文件与远程文件进行同步。
在本申请的一些实施例中,基于以上技术方案,根据本申请实施例的一个方面,提供一种数据同步装置,包括:
信息获取模块,用于获取各个远程文件的文件信息,所述文件信息包括版本信息;
信息更新模块,用于根据所述各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对所述各个本地文件的文件信息进行更新,得到各个更新文件;
消息获取模块,用于展示所述各个更新文件,并获取待同步文件选择消息,所述待同步文件选择消息中包括从所述各个更新文件中确定的待同步文件;
文件同步模块,用于根据所述待同步文件的版本信息,将所述待同步文件与远程文件进行同步。
在本申请的一些实施例中,基于以上技术方案,所述文件信息包含描述信息和文件标识;信息更新模块包括:
关系确定单元,用于根据所述各个远程文件的文件标识和所述各个本地文件的文件标识,确定所述远程文件与所述本地文件的对应关系;
描述信息同步单元,用于对于存在对应的远程文件的本地文件,根据所述本地文件的版本信息和对应的远程文件的版本信息的比对结果,将所述远程文件的描述信息与所述本地文件的描述信息同步;
本地文件生成单元,用于对于不存在对应的本地文件的远程文件,根据所述远程文件的文件信息生成对应的本地文件;
文件更新单元,用于将所生成的本地文件和更新后的本地文件,确定为更新文件。
在本申请的一些实施例中,基于以上技术方案,描述信息同步单元包括:
状态设置子单元,用于若所述本地文件的版本信息大于对应的远程文件的版本信息,将所述本地文件的同步状态设置为待上传状态,以便于触发根据所述本地文件更新对应的远程文件的同步操作;
描述信息更新子单元,用于若所述本地文件的版本信息小于对应的远程文件的版本信息,则根据所述远程文件的描述信息更新所述待同步文件的描述信息。
在本申请的一些实施例中,基于以上技术方案,所述描述信息更新子单元还用于若所述本地文件的同步状态处于待上传状态,则复制所述本地文件以生成所述本地文件的文件副本,并且利用所述远程文件的描述信息替换所述本地文件的描述信息。
在本申请的一些实施例中,基于以上技术方案,所述文件同步模块包括:
状态检查单元,用于若所述待同步文件的版本信息小于所述远程文件的版本信息,检查所述目标你文件的同步状态;
内容替换单元,用于若所述待同步文件的同步状态处于已上传状态,则将所述待同步文件的文件内容替换为所述远程文件的文件内容;
副本发送单元,用于若所述待同步文件的同步状态处于待上传状态,则复制所述待同步文件以生成所述待同步文件的文件副本,并将所述待同步文件的文件副本发送给所述服务器以进行数据同步。
在本申请的一些实施例中,基于以上技术方案,数据同步装置还包括:
文件获取模块,用于从所述各个更新文件中获取中处于待上传状态的待上传文件;
描述信息生成模块,用于根据所述待上传文件的文件内容,生成并替换所述待上传文件的描述信息;
文件上传模块,用于将所述待上传文件发送到服务器以使所述服务器根据所述待上传文件进行数据同步。
在本申请的一些实施例中,基于以上技术方案,所述描述信息生成模块包括:
内容获取单元,用于获取所述待上传文件的文件内容;
文本截取单元,用于若所述文件内容包括两行或者两行以上的文本内容,截取其中所述文件内容中的至少一行文本数据;
描述信息替换单元,用于将截取到的至少一行文本数据作为所述待上传文件的描述信息并替换所述待上传文件的描述信息。
在本申请的一些实施例中,基于以上技术方案,数据同步装置还包括:
权重计算模块,用于基于所述本地文件的修改历史,计算各个本地文件的优先权权重,其中,所述修改历史包括以下信息中的至少一种:修改时间、修改频率和修改次数;
序列确定模块,用于根据所述本地文件的优先权权重,确定各个本地文件的上传序列;
文件同步模块,用于根据所述上传序列,将所述各个本地文件与对应的远程文件进行同步。
根据本申请实施例的一个方面,提供一种电子设备,该到电子设备包括:处理器;以及存储器,用于存储处理器的可执行指令;其中,该处理器配置为经由执行可执行指令来执行如以上技术方案中的数据同步的方法。
根据本申请实施例的一个方面,提供一种计算机可读存储介质,其上存储有计算机程序,当该计算机程序被处理器执行时实现如以上技术方案中的数据同步的方法。
在本申请的实施例中,在进行草稿同步时,首先同步各个草稿的文件信息,再根据用户选择的待同步文件,从而可以仅同步要编辑的待同步文件的文件内容,从而降低草稿的数据同步过程的数据量,提升响应速度,进而能够避免同步过程阻塞用户操作,改善用户体验。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本申请。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本申请的实施例,并与说明书一起用于解释本申请的原理。显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
在附图中:
图1为本申请技术方案在一个应用场景中的示例性系统构架示意图;
图2是本申请实施例提供的一种数据同步方法的流程图;
图3为本申请实施例中云草稿列表同步方案的流程示意图;
图4为本申请实施例中云草稿文件同步方案的流程示意图;
图5示意性地示出了本申请实施例中数据同步装置的组成框图;
图6示出了适于用来实现本申请实施例的电子设备的计算机系统的结构示意图。
具体实施方式
现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的范例;相反,提供这些实施方式使得本申请将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。
此外,所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施例中。在下面的描述中,提供许多具体细节从而给出对本申请的实施例的充分理解。然而,本领域技术人员将意识到,可以实践本申请的技术方案而没有特定细节中的一个或更多,或者可以采用其它的方法、组元、装置、步骤等。在其它情况下,不详细示出或描述公知方法、装置、实现或者操作以避免模糊本申请的各方面。
附图中所示的方框图仅仅是功能实体,不一定必须与物理上独立的实体相对应。即,可以采用软件形式来实现这些功能实体,或在一个或多个硬件模块或集成电路中实现这些功能实体,或在不同网络和/或处理器装置和/或微控制器装置中实现这些功能实体。
附图中所示的流程图仅是示例性说明,不是必须包括所有的内容和操作/步骤,也不是必须按所描述的顺序执行。例如,有的操作/步骤还可以分解,而有的操作/步骤可以合并或部分合并,因此实际执行的顺序有可能根据实际情况改变。
应理解,本申请可以应用于社交平台和各类信息、文章或者媒体信息发布平台、以及各类具有内容发布功能的平台。用户在此类平台中,用户在客户端中编辑的草稿文件可以被同步到云端中保存,并且当用户登录到另一个设备时从云端下载继续编辑。然而,当用户保存的草稿较多时,客户端需要先与服务器同步各个草稿中的内容,然后才能允许客户对草稿进行编辑。通过本申请的方案,客户端在同步草稿时,首先会仅同步草稿的文件信息,例如草稿的摘要,并且展示给用户,当用户选择了具体想要编辑的草稿时,才会继续同步该草稿的具体内容,从而达到降低同步过程的数据量,提高响应速度的效果。
下面介绍以社交平台为例介绍本申请的应用场景。请参阅图1,图1为本申请技术方案在一个应用场景中的示例性系统构架示意图。
如图1所示,在该系统架构中包括终端110、云服务器120和终端130。终端110和终端130与云服务器120存在网络连接。
终端110和终端130均可以是智能手机、平板电脑、笔记本电脑、台式计算机、智能音箱、智能手表等,但并不局限于此。终端110安装和运行有用于进行信息发布的客户端,例如动态发布或者文章发布功能等功能,或者通过浏览器等网络浏览应用来访问相应网站。云服务器120可以是独立的物理服务器,也可以是多个物理服务器构成的服务器集群或者分布式系统,还可以是提供云服务、云数据库、云计算、云函数、云存储、网络服务、云通信、中间件服务、域名服务、安全服务、CDN(Content Delivery Network,内容分发网络)、以及大数据和人工智能平台等基础云计算服务的云服务器。订单服务器120用于为终端110和终端130所运行的客户端提供后台服务。
云服务器120可以为用户提供云草稿的服务器。用户首先可以在终端110上编辑草稿A。草稿A会被上传到云服务器120中。当用户在另一个终端130上登录时。终端会与云服务器120通信来获取通过终端110上传的草稿A。可以理解的是,终端130上可以已经存储了之前建立的草稿。在同步的过程中,终端130中已经存储的草稿会根据草稿的状态来根据云服务器120上的草稿来更新本地的草稿。用户可以在终端130上编辑同步得到的草稿A,得到草稿A’,并且与云服务器120同步来更新将云服务器120上的草稿A替换成草稿A’。当用户再次到终端110上登录时,终端110会与云服务器120同步来将本地的草稿A替换成终端130编辑过并且上传的草稿A’。
上述终端110和终端130与云服务器120之间可以通过有线或无线通信方式进行直接或间接地连接,本申请实施例对此不作限定。
本领域技术人员可以知晓,上述终端的数量可以更多或更少。比如上述终端可以仅为一个,或者上述终端为几十个或几百个,或者更多数量。本申请实施例对终端的数量和设备类型不加以限定。下面结合具体实施方式对本申请提供的技术方案做出详细说明。
为了便于介绍,请参阅图2,图2是本申请实施例提供的一种数据同步方法的流程图。该方法可以应用于上述的终端,在本申请实施例中,以终端的计算机设备作为执行主体,对该数据同步方法进行介绍,该数据同步方法可以包括以下步骤S210至步骤S240:
步骤S210,获取各个远程文件的文件信息,文件信息包括版本信息。
远程文件指的是终端同步到云服务器中进行存储的文件,例如草稿文件。文件信息指的是远程文件的本身内容之外的文件描述内容,例如,文件的名称、文件描述信息和文件内容简介等内容。获取的过程可以分页执行,客户端根据分页展示中每页的数量需要,从服务器获取对应数量的远程文件的文件信息,并且循环直至云端中没有更多文件。
步骤S220,根据各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对各个本地文件的文件信息进行更新,得到各个更新文件。
本地文件是存储在客户端的计算机设备中的文件。相匹配的远程文件和本地文件可以是同一份草稿文件的相同版本或者不同版本。匹配的过程可以基于文件的文件名或者编号等来确定。对于相匹配的远程文件和本地文件,则需要对本地文件的文件信息进行对应的更新,以使得本地文件的文件信息能够对应于最近版本的文件,得到更新文件。在远程文件的版本晚于本地文件的情况下,更新文件中会包括远程文件的文件信息以及本地文件的文件内容,即使二者并不完全匹配。更新文件可以向用户进行展示,所展示的内容主要包括文件信息中的内容,例如名称、摘要、更新时间等。用户则可以根据所展示出的更新文件的文件信息来选择想要编辑的文件,从而进一步对文件的具体内容进行更新。
步骤S230,获取待同步文件选择消息,待同步文件选择消息中包括从各个更新文件中确定的待同步文件。
待同步文件选择消息是根据用户的选择生成的消息。各个更新文件构成的列表被展示给用户后,用户可以从中选择一个文件作为待同步文件来进行编辑。客户端则会根据用户的选择操作,获取到用户所选择的文件来生成待同步文件选择消息,以便触发后续的过程。
步骤S240,根据待同步文件的版本信息,将待同步文件与远程文件进行同步。
在确定用户选择的待同步文件之后,则可以根据待同步文件的版本信息来进行同步。如果待同步文件的版本是最初的版本,或者待同步文件不存在对应的远程文件,则可以跳过同步过程。如果存在对应远程文件,则需要根据版本信息来确定待同步文件和远程文件中哪一个文件是最近更新的文件,并且根据最近更新的文件来更新对方的文件内容。此外,根据待同步文件是否已经被上传到服务器,在进行同步或者覆盖之前,还需要将未上传的内容保存起来,以防止用户编辑的内容丢失。
在本申请的实施例中,在进行草稿同步时,首先同步各个草稿的文件信息,再根据用户选择的待同步文件,从而可以仅同步要编辑的待同步文件的文件内容,从而降低草稿的数据同步过程的数据量,提升响应速度,进而能够避免同步过程阻塞用户操作,改善用户体验。
在一个实施例中,基于上述的方案,文件信息包含描述信息和文件标识;上述步骤S220,根据各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对各个本地文件的文件信息进行更新,得到各个更新文件,包括如下的步骤:
根据各个远程文件的文件标识和各个本地文件的文件标识,确定远程文件与本地文件的对应关系;
对于存在对应的远程文件的本地文件,根据本地文件的版本信息和对应的远程文件的版本信息的比对结果,将远程文件的描述信息与本地文件的描述信息同步;
对于不存在对应的本地文件的远程文件,根据远程文件的文件信息生成对应的本地文件;
将所生成的本地文件和更新后的本地文件,确定为更新文件。
具体地,具有相同的文件标识的远程文件和本地文件之间可以建立对应关系,它们是同一份文件的相同或不同版本。每个远程文件对应于一个本地文件。然而,不一定每个远程文件都存在对应的本地文件,也不一定每个本地文件都存在对应的远程文件,例如,终端在不联网的情况下建立的本地文件可能不存在对应的远程文件,而在另一个设备上传的远程文件也可能在当前设备上没有对应的本地文件。
对于存在对应的远程文件的本地文件,将本地文件的版本信息与对应的远程文件的版本信息进行比较,根据比较结果来确定哪个文件的版本是最新的,从而将远程文件的描述信息与本地文件的描述信息同步。需要注意的是,同步的过程可以是利用远程文件的描述信息覆盖本地文件的描述信息,也可以是相反的,用本地文件的描述信息覆盖远程文件的描述信息。需要注意的是,更新的部分仅涉及文件的描述信息,而没有更新文件的文件内容。在一个实施例中,文件的所有文件信息都可以根据比较结果来进行同步。
对于不存在对应的本地文件的远程文件,则可以直接将远程文件的文件信息下载下来并生成本地文件。此时,所生成的本地文件的文件内容是空的。
将所生成的本地文件和更新后的本地文件都被确定更新文件,它们一起构成了要向用户展示的文件列表,并且被展示给用户以允许用户从中选择想要编辑的待同步文件。
在一个实施例中,基于上述的方案,上述步骤,述根据本地文件的版本信息和对应的远程文件的版本信息的比对结果,将远程文件的描述信息与本地文件的描述信息同步,包括如下的步骤:
若本地文件的版本信息大于对应的远程文件的版本信息,将本地文件的同步状态设置为待上传状态,以便于触发根据本地文件更新对应的远程文件的同步操作;
若待同步文件的版本信息小于对应的远程文件的版本信息,则根据远程文件的描述信息更新待同步文件的描述信息。
具体地,本地文件的版本信息大于对应的远程文件的版本信息,表示本地文件的版本是最新的版本,则不需要更新本地文件的描述信息。将本地文件的同步状态设置为待上传状态,以便于触发根据本地文件更新对应的远程文件的同步操作。客户端在运行过程中会自动以及根据用户操作触发同步操作。同步操作中会将所有处于待上传状态的本体文件同步到服务器中。同步的过程中可以将多个本地文件同步上传。
待同步文件的版本信息小于对应的远程文件的版本信息,表示远程文件的版本是最新版本,则需要将本地文件的描述信息更新为远程文件的描述信息。
对于本地文件的版本信息等于对应的远程文件的版本信息的情况,则不需要进行处理,可以直接跳过该文件的同步过程。
在一个实施例中,基于上述的方案,上述步骤,根据远程文件的描述信息更新本地文件的描述信息,包括如下的步骤:
若本地文件的同步状态处于待上传状态,则复制本地文件以生成本地文件的文件副本,并且利用远程文件的描述信息替换本地文件的描述信息。
本地文件的同步状态处于待上传状态,则表示该文件虽然在服务器上存在更新的版本,但是在本地也对该文件进行了编辑,因此,可以将本地文件复制一份成为文件副本,从而保留在本地编辑的内容,然后将原本的本地文件的描述信息更新为远程文件的描述信息。
在一个实施例中,基于上述的方案,上述步骤S240,根据待同步文件的版本信息,将待同步文件与远程文件进行同步,包括:
若待同步文件的版本信息小于远程文件的版本信息,检查目标你文件的同步状态;
若待同步文件的同步状态处于已上传状态,则将待同步文件的文件内容替换为远程文件的文件内容;
若待同步文件的同步状态处于待上传状态,则复制待同步文件以生成待同步文件的文件副本,并将待同步文件的文件副本发送给服务器以进行数据同步。
如果待同步文件的版本信息小于远程文件的版本信息,检查目标你文件的同步状态。如果待同步文件的版本信息大于或者等于远程文件的版本信息,则不需要同步文件的文件内容,同步过程可以直接结果。如果待同步文件的同步状态处于已上传状态,则将待同步文件的文件内容替换为远程文件的文件内容,此时则完成了将待同步文件与远程文件完全同步的过程,并且不会丢失本地文件修改的内容。如果待同步文件的同步状态处于待上传状态,则表示本地文件中含有未上传的内容,此时,远程文件和待同步文件双方都含有需要同步的内容,复制待同步文件以生成待同步文件的文件副本,以便保存本地的修改内容,并将待同步文件的文件副本发送给服务器以进行数据同步,从而在服务器保存在本地编辑的内容。
在一个实施例中,基于上述的方案,上述步骤S230,获取待同步文件选择消息之前,方法还包括如下步骤:
从各个更新文件中获取中处于待上传状态的待上传文件;
根据待上传文件的文件内容,生成并替换待上传文件的描述信息;
将待上传文件发送到服务器以使服务器根据待上传文件进行数据同步。
具体地,在同步了各个本地文件的描述信息之后,终端可以先将本地处于待上传状态的本地文件先同步到服务器。首先,从各个更新文件中获取中处于待上传状态的待上传文件,此类文件可以理解为在终端处于离线状态时编辑的文件,或者之前由于故障上传失败的本地文件。随后,根据待上传文件的文件内容,生成并替换待上传文件的描述信息。在上传之前更新描述信息从而保证描述信息与文件内容是相匹配的状态。之后,将待上传文件发送到服务器以使服务器根据待上传文件进行数据同步。具体地,在发送待上传文件时,可以将文件的版本信息累加来递增版本。需要同步的待上传文件可以是各个文件中老版本的历史存量草稿。这些草稿在获取待上传文件之前检查所有本地文件的历史版本,并且将所有未上传的历史文件设置为待上传状态,从而成为待上传文件。
在一个实施例中,基于上述的方案,上述步骤,根据待上传文件的文件内容,生成并替换待上传文件的描述信息的过程可以包括:获取待上传文件的文件内容;若文件内容包括两行或者两行以上的文本内容,截取其中文件内容中的至少一行文本数据。在文件内容包含超过两行的内容时,通常会截取文件内容中的第一行。将截取到的至少一行文本数据作为待上传文件的描述信息并替换待上传文件的描述信息。
在一个实施例中,基于上述的方案,上述方法还包括:
基于所述本地文件的修改历史,计算各个本地文件的优先权权重,其中,所述修改历史包括以下信息中的至少一种:修改时间、修改频率和修改次数;根据所述本地文件的优先权权重,确定各个本地文件的上传序列;根据所述上传序列,将所述各个本地文件与对应的远程文件进行同步。具体地,在计算优先权权重中,首先要确定各个计算参数的权重值。对于修改时间,可以通过将各个本地文件的最近修改时间进行降序排序,修改时间越近的权重值越高。对于修改频率,可以根据预定时间段内的修改频率的大小进行排序来确定权重值。对于修改次数,也可以根据预定时间段内的修改次数的大小来确定对应权重值。在确定权重值的过程中,可以通过归一化的方式来进行单位统一。具体地,优先权权重可以采用如下计算公式:
Figure BDA0003443147330000121
其中,P为优先权权重,S为本地文件的数量,mi为修改时间排序为第i个本地文件的次序,ni为第i个本地文件的修改频率,hi为第i个本地文件的修改次数。根据优先权权重,可以确定本地文件的上传次数,从而将修改时间近、频率高并且次数多的本地文件优先上传到服务器。下面以草稿为例介绍本申请的具体方案,为了便于介绍,请参阅图3,图3为本申请实施例中云草稿列表同步方案的流程示意图。如图3所示,软件程序以列表的形式组织和展示草稿。首先,当用户在软件程序中进入草稿功能时,软件程序根据程序本地存储的草稿列表来从服务器的云端增量获取云端草稿列表。在获取成功后,首先会判断返回的云端草稿列表中的草稿在本地的列表中已经存在。对于不存在的草稿,软件会按照云端草稿新建一份本地草稿。对于在云端草稿列表中已经存在的文件,会检查该本地草稿中是否已经被上传到服务器。如果本地草稿还未上传到服务器,则会比较本地草稿和云端草稿的版本,如果本地版本等于或者大于云端版本,则不需要进行额外操作。如果本地版本小于云端版本,则将本地草稿复制出一份副本,并且利用云端的草稿覆盖本地草稿。如果本地草稿已经被上传到服务器,也会比较本地草稿和云端草稿的版本。如果本地版本等于云端版本,则不需要进行额外操作,如果本地版本大于云端版本,则将本地草稿设置为为发送的状态。如果本地版本小于云端版本,则更新本地草稿。至此,获取云端列表完成。最后,开始处理未发送到远端的草稿。在草稿中检查是否存在老版本存量草稿。如果存在,则将存量草稿转换为未上云的状态。循环检查所有的草稿后,开始检查是否存在未上云的草稿,如果存在,则将未上云的草稿上传,直到所有草稿都上传。
下面介绍单个草稿的详细同步过程。为了便于介绍,请参阅图4,图4为本申请实施例中云草稿文件同步方案的流程示意图。上述过程结束后会展示出草稿列表,用户可以在草稿列表中选择想要编辑的草稿并且点击,从而触发单个云草稿文件的同步过程。如图4所示,应用会按照用户的点击进入云草稿详情页面,随后检查该云草稿是否已经被上传到云端。如果云草稿还未上传到云端,则应用将会该草稿上传到云端。云端接收到草稿后,会检查云端存储的草稿,如果存在该草稿,则会将云端的草稿发送给终端。终端在则会在比较本地版本和云端版本,如果本地版本大于云端版本,则直接展示草稿详情,否则,如果本地版本等于或者小于云端版本,则会拷贝本地的草稿副本,随后,获取云端的草稿详情并且覆盖本地的云草稿,并且上传复制出的草稿副本,之后,则可以向用户展示本覆盖过的云草稿和草稿副本。如果云草稿已经被上传到云端,则终端会获取云端草稿的草稿详情,并且比较本地版本和云端版本。如果本地版本小于云端版本,则将本地草稿设置为未上传状态,否则,则用云端草稿覆盖本地草稿。
应当注意,尽管在附图中以特定顺序描述了本申请中方法的各个步骤,但是,这并非要求或者暗示必须按照该特定顺序来执行这些步骤,或是必须执行全部所示的步骤才能实现期望的结果。附加的或备选的,可以省略某些步骤,将多个步骤合并为一个步骤执行,以及/或者将一个步骤分解为多个步骤执行等。
以下介绍本申请的装置实施,可以用于执行本申请上述实施例中的数据同步的方法。图5示意性地示出了本申请实施例中数据同步装置的组成框图。如图5所示,数据同步装置500主要可以包括:
信息获取模块510,用于获取各个远程文件的文件信息,文件信息包括版本信息;
信息更新模块520,用于根据各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对各个本地文件的文件信息进行更新,得到各个更新文件;
消息获取模块530,用于展示各个更新文件,并获取待同步文件选择消息,待同步文件选择消息中包括从各个更新文件中确定的待同步文件;
文件同步模块540,用于根据待同步文件的版本信息,将待同步文件与远程文件进行同步。
在本申请的一些实施例中,基于以上技术方案,文件信息包含描述信息和文件标识;信息更新模块520包括:
关系确定单元,用于根据各个远程文件的文件标识和各个本地文件的文件标识,确定远程文件与本地文件的对应关系;
描述信息同步单元,用于对于存在对应的远程文件的本地文件,根据本地文件的版本信息和对应的远程文件的版本信息的比对结果,将远程文件的描述信息与本地文件的描述信息同步;
本地文件生成单元,用于对于不存在对应的本地文件的远程文件,根据远程文件的文件信息生成对应的本地文件;
文件更新单元,用于将所生成的本地文件和更新后的本地文件,确定为更新文件。
在本申请的一些实施例中,基于以上技术方案,描述信息同步单元包括:
状态设置子单元,用于若本地文件的版本信息大于对应的远程文件的版本信息,将本地文件的同步状态设置为待上传状态,以便于触发根据本地文件更新对应的远程文件的同步操作;
描述信息更新子单元,用于若本地文件的版本信息小于对应的远程文件的版本信息,则根据远程文件的描述信息更新待同步文件的描述信息。
在本申请的一些实施例中,基于以上技术方案,描述信息更新子单元还用于若本地文件的同步状态处于待上传状态,则复制本地文件以生成本地文件的文件副本,并且利用远程文件的描述信息替换本地文件的描述信息。
在本申请的一些实施例中,基于以上技术方案,文件同步模块540包括:
状态检查单元,用于若待同步文件的版本信息小于远程文件的版本信息,检查目标你文件的同步状态;
内容替换单元,用于若待同步文件的同步状态处于已上传状态,则将待同步文件的文件内容替换为远程文件的文件内容;
副本发送单元,用于若待同步文件的同步状态处于待上传状态,则复制待同步文件以生成待同步文件的文件副本,并将待同步文件的文件副本发送给服务器以进行数据同步。
在本申请的一些实施例中,基于以上技术方案,数据同步装置500还包括:
文件获取模块,用于从各个更新文件中获取中处于待上传状态的待上传文件;
描述信息生成模块,用于根据待上传文件的文件内容,生成并替换待上传文件的描述信息;
文件上传模块,用于将待上传文件发送到服务器以使服务器根据待上传文件进行数据同步。
在本申请的一些实施例中,基于以上技术方案,描述信息生成模块包括:
内容获取单元,用于获取待上传文件的文件内容;
文本截取单元,用于若文件内容包括两行或者两行以上的文本内容,截取其中文件内容中的至少一行文本数据;
描述信息替换单元,用于将截取到的至少一行文本数据作为待上传文件的描述信息并替换待上传文件的描述信息。
在本申请的一些实施例中,基于以上技术方案,数据同步装置500还包括:
权重计算模块,用于基于所述本地文件的修改历史,计算各个本地文件的优先权权重,其中,所述修改历史包括以下信息中的至少一种:修改时间、修改频率和修改次数;
序列确定模块,用于根据所述本地文件的优先权权重,确定各个本地文件的上传序列;
文件同步模块,用于根据所述上传序列,将所述各个本地文件与对应的远程文件进行同步。
需要说明的是,上述实施例所提供的装置与上述实施例所提供的方法属于同一构思,其中各个模块执行操作的具体方式已经在方法实施例中进行了详细描述,此处不再赘述。
图6示出了适于用来实现本申请实施例的电子设备的计算机系统的结构示意图。
需要说明的是,图6示出的电子设备的计算机系统600仅是一个示例,不应对本申请实施例的功能和使用范围带来任何限制。
如图6所示,计算机系统600包括中央处理单元(Central Processing Unit,CPU)601,其可以根据存储在只读存储器(Read-Only Memory,ROM)602中的程序或者从储存部分608加载到随机访问存储器(Random Access Memory,RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有系统操作所需的各种程序和数据。CPU 601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(Input/Output,I/O)接口605也连接至总线604。
以下部件连接至I/O接口605:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(Cathode Ray Tube,CRT)、液晶显示器(Liquid Crystal Display,LCD)等以及扬声器等的输出部分607;包括硬盘等的储存部分608;以及包括诸如LAN(Local Area Network,局域网)卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口605。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便于从其上读出的计算机程序根据需要被安装入储存部分608。
特别地,根据本申请的实施例,各个方法流程图中所描述的过程可以被实现为计算机软件程序。例如,本申请的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被中央处理单元(CPU)601执行时,执行本申请的系统中限定的各种功能。
需要说明的是,本申请实施例所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(Erasable Programmable Read Only Memory,EPROM)、闪存、光纤、便携式紧凑磁盘只读存储器(Compact Disc Read-Only Memory,CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本申请中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本申请中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、有线等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本申请的实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本申请实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、触控终端、或者网络设备等)执行根据本申请实施方式的方法。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本申请的其它实施方案。本申请旨在涵盖本申请的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本申请的一般性原理并包括本申请未公开的本技术领域中的公知常识或惯用技术手段。
应当理解的是,本申请并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本申请的范围仅由所附的权利要求来限制。

Claims (10)

1.一种数据同步的方法,其特征在于,包括:
获取各个远程文件的文件信息,所述文件信息包括版本信息;
根据所述各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对所述各个本地文件的文件信息进行更新,得到各个更新文件;
展示所述各个更新文件,并获取待同步文件选择消息,所述待同步文件选择消息中包括从所述各个更新文件中确定的待同步文件;
根据所述待同步文件的版本信息,将所述待同步文件与远程文件进行同步。
2.根据权利要求1所述的方法,其特征在于,所述文件信息还包含描述信息和文件标识;所述根据所述各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对所述各个本地文件的文件信息进行更新,得到各个更新文件,包括:
根据所述各个远程文件的文件标识和所述各个本地文件的文件标识,确定所述远程文件与所述本地文件的对应关系;
对于存在对应的远程文件的本地文件,根据所述本地文件的版本信息和对应的远程文件的版本信息的比对结果,将所述远程文件的描述信息与所述本地文件的描述信息同步;
对于不存在对应的本地文件的远程文件,根据所述远程文件的文件信息生成对应的本地文件;
将所生成的本地文件和更新后的本地文件,确定为更新文件。
3.根据权利要求2所述的方法,其特征在于,所述根据所述本地文件的版本信息和对应的远程文件的版本信息的比对结果,将所述远程文件的描述信息与所述本地文件的描述信息同步,包括:
若所述本地文件的版本信息大于对应的远程文件的版本信息,将所述本地文件的同步状态设置为待上传状态,以便于触发根据所述本地文件更新对应的远程文件的同步操作;
若所述本地文件的版本信息小于对应的远程文件的版本信息,则根据所述远程文件的描述信息更新所述待同步文件的描述信息。
4.根据权利要求3所述的方法,其特征在于,所述根据所述远程文件的描述信息更新所述待同步文件的描述信息,包括:
若所述本地文件的同步状态处于待上传状态,则复制所述本地文件以生成所述本地文件的文件副本,并且利用所述远程文件的描述信息替换所述本地文件的描述信息。
5.根据权利要求1所述的方法,其特征在于,所述根据所述待同步文件的版本信息,将所述待同步文件与远程文件进行同步,包括:
若所述待同步文件的版本信息小于所述远程文件的版本信息,检查所述目标文件的同步状态;
若所述待同步文件的同步状态处于已上传状态,则将所述待同步文件的文件内容替换为所述远程文件的文件内容;
若所述待同步文件的同步状态处于待上传状态,则复制所述待同步文件以生成所述待同步文件的文件副本,并将所述待同步文件的文件副本发送给所述服务器以进行数据同步。
6.根据权利要求1所述的方法,其特征在于,所述获取待同步文件选择消息之前,所述方法还包括:
从所述各个更新文件中获取中处于待上传状态的待上传文件;
根据所述待上传文件的文件内容,生成并替换所述待上传文件的描述信息;
将所述待上传文件发送到服务器以使所述服务器根据所述待上传文件进行数据同步。
7.根据权利要求1所述的方法,其特征在于,所述方法还包括:
基于所述本地文件的修改历史,计算各个本地文件的优先权权重,其中,所述修改历史包括以下信息中的至少一种:修改时间、修改频率和修改次数;
根据所述本地文件的优先权权重,确定各个本地文件的上传序列;
根据所述上传序列,将所述各个本地文件与对应的远程文件进行同步。
8.一种数据同步装置,其特征在于,包括:
信息获取模块,用于获取各个远程文件的文件信息,所述文件信息包括版本信息;
信息更新模块,用于根据所述各个远程文件的文件信息和本地存储的各个本地文件的文件信息的匹配结果,对所述各个本地文件的文件信息进行更新,得到各个更新文件;
消息获取模块,用于展示所述各个更新文件,并获取待同步文件选择消息,所述待同步文件选择消息中包括从所述各个更新文件中确定的待同步文件;
文件同步模块,用于根据所述待同步文件的版本信息,将所述待同步文件与远程文件进行同步。
9.一种电子设备,其特征在于,包括:
处理器;
存储器,用于存储所述处理器的可执行指令;
其中,所述处理器配置为经由执行所述可执行指令来执行权利要求1至7中任意一项所述的数据同步的方法。
10.一种计算机可读介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至7中任一项所述的数据同步的方法。
CN202111647526.5A 2021-12-29 2021-12-29 数据同步的方法、装置、电子设备和可读介质 Pending CN114385570A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202111647526.5A CN114385570A (zh) 2021-12-29 2021-12-29 数据同步的方法、装置、电子设备和可读介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111647526.5A CN114385570A (zh) 2021-12-29 2021-12-29 数据同步的方法、装置、电子设备和可读介质

Publications (1)

Publication Number Publication Date
CN114385570A true CN114385570A (zh) 2022-04-22

Family

ID=81199746

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202111647526.5A Pending CN114385570A (zh) 2021-12-29 2021-12-29 数据同步的方法、装置、电子设备和可读介质

Country Status (1)

Country Link
CN (1) CN114385570A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114706831A (zh) * 2022-06-06 2022-07-05 天津联想协同科技有限公司 一种网盘文件的同步方法及装置

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114706831A (zh) * 2022-06-06 2022-07-05 天津联想协同科技有限公司 一种网盘文件的同步方法及装置

Similar Documents

Publication Publication Date Title
CN108845816B (zh) 应用程序更新方法、系统、计算机设备及存储介质
CN107203395A (zh) 资源升级方法、装置及计算机可读存储介质和电子设备
CN108228282A (zh) 用于网站页面加载的方法及装置
CN103152398A (zh) 一种多终端文件间的文件同步方法及系统
CN110895603B (zh) 多系统账号信息整合方法和装置
CN107918617B (zh) 数据查询方法和装置
CN111800468A (zh) 一种基于云的多集群管理方法、装置、介质及电子设备
CN110727468A (zh) 管理算法模型的方法和装置
CN112860343B (zh) 配置变更方法、系统、装置、电子设备以及存储介质
CN111782235A (zh) 一种数据升级、查询方法和装置
CN111708836B (zh) 集群管理的方法、设备和集群系统
CN107347093B (zh) 用于分布式服务器系统的配置方法和装置
CN110825425A (zh) 配置数据管理方法及装置、电子设备、存储介质
CN114385570A (zh) 数据同步的方法、装置、电子设备和可读介质
CN110096295B (zh) 基于ReactNative的多模块移动应用的热更新方法及系统
CN111767495A (zh) 一种合成网页的方法及系统
CN110852701A (zh) 产品需求管理方法、装置和系统
CN109150694A (zh) 动态场景信息的发送方法、显示方法及服务器和移动终端
CN115329864A (zh) 训练推荐模型的方法、装置和电子设备
CN111865576B (zh) 一种同步url分类数据的方法和装置
CN114490124A (zh) 调用应用程序编程接口api的方法、装置、设备及介质
CN113486116A (zh) 一种数据同步方法、装置、电子设备及计算机可读介质
CN114064100A (zh) 配置信息处理方法、系统和装置
CN113760841A (zh) 实现分布式锁的方法和装置
CN112579615A (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