CN110032383A - 软件更新方法、装置及存储介质 - Google Patents
软件更新方法、装置及存储介质 Download PDFInfo
- Publication number
- CN110032383A CN110032383A CN201910286174.1A CN201910286174A CN110032383A CN 110032383 A CN110032383 A CN 110032383A CN 201910286174 A CN201910286174 A CN 201910286174A CN 110032383 A CN110032383 A CN 110032383A
- Authority
- CN
- China
- Prior art keywords
- software installation
- mapping file
- installation package
- block
- data
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 65
- 238000013507 mapping Methods 0.000 claims description 140
- 238000004590 computer program Methods 0.000 claims description 18
- 238000000638 solvent extraction Methods 0.000 claims description 17
- 238000012545 processing Methods 0.000 claims description 9
- 238000005192 partition Methods 0.000 claims description 7
- 238000010276 construction Methods 0.000 claims description 2
- 238000010586 diagram Methods 0.000 description 13
- 230000008569 process Effects 0.000 description 8
- 230000000694 effects Effects 0.000 description 6
- 230000000903 blocking effect Effects 0.000 description 3
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 238000011161 development Methods 0.000 description 3
- 238000004891 communication Methods 0.000 description 2
- 238000009434 installation Methods 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 238000012856 packing Methods 0.000 description 2
- 238000007670 refining Methods 0.000 description 2
- 230000008859 change Effects 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000002194 synthesizing effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
- G06F8/71—Version control; Configuration management
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明提供一种软件更新方法、装置及存储介质。服务器获取最新版本软件安装包,将软件安装包划分为多个不同大小的数据块,获取各数据块对应的数据指纹信息,生成软件安装包的分块映射文件,将软件安装包、分块映射文件以及软件安装包的版本信息文件存储在服务器的数据库中,以便客户端根据不同版本软件安装包的分块映射文件确定最新版本软件安装包中各数据块的操作模式,并根据操作模式构建新的软件安装包。上述方法解决了不相邻软件版本更新效率低的问题,提高了软件增量更新效率。
Description
技术领域
本发明实施例涉及软件生成和更新技术领域,尤其涉及一种软件更新方法、装置及存储介质。
背景技术
一款软件产品在发布后需要不断的维护和改进,软件产品的开发人员通过不同方式将这些更新后的软件产品推送给用户终端,此过程称为软件更新。最早的软件开发周期很长,软件更新的频率很低,可能一个月或者几个月更新一次,维护一个软件更新服务相对简单,提醒用户下载最新版本的软件产品覆盖安装即可。
随着软件开发进行移动互联网的高速发展时代,软件产品的竞争日趋激烈,快速频繁的软件版本发布成为主流的开发模式,开发周期大大缩短,这给软件更新服务带来了新的挑战。如果按照原来的更新模式,让用户每周或者几天下载更新完整的软件安装包,将浪费用户的带宽,在网络不理想的情况下,可能导致下载失败,极大影响用户体验。
针对上述问题目前的解决方案是采用增量更新,即用户不需要下载完整的软件安装包,只需要下载增量部分。增量更新目前比较成熟的算法是bsdiff/bspatch算法,该算法虽然只下载部分增量,但只能作用于相邻的软件版本,也就是说,如果用户安装的版本与最新版本不相邻,则服务器端需要打包多个补丁来应对不同版本与最新版本的差异,使得打包过程非常繁琐,同时客户端根据多个补丁合成最新版本的过程也十分耗时。
发明内容
本发明提供一种软件更新方法、装置及存储介质,解决了不相邻软件版本的更新效率低的问题。
本发明的第一方面提供一种软件更新方法,包括:
获取最新版本软件安装包;
将所述软件安装包划分为多个不同大小的数据块;
获取各所述数据块对应的数据指纹信息,生成所述软件安装包的分块映射文件;
将所述软件安装包、所述分块映射文件以及所述软件安装包的版本信息文件存储在服务器的数据库中。
在一种可能的实现方式中,所述将所述软件安装包划分为多个数据块,包括:
根据固定滑动窗口计算所述固定滑动窗口内的软件安装包的哈希值,若所述哈希值与预设基准值匹配,则创建所述软件安装包的一个数据块;
通过上述步骤将所述软件安装包划分为多个不同大小的数据块。
在一种可能的实现方式中,所述生成所述软件安装包的分块映射文件,包括:
根据各所述数据块的划分顺序,对各所述数据块对应的数据指纹信息进行序列化处理,得到所述软件安装包的分块映射文件。
在一种可能的实现方式中,所述数据指纹信息包括数据块的大小、哈希值以及偏移值的至少一种。
本发明的第二方面提供一种软件更新方法,包括:
获取本地软件安装包的第一分块映射文件和最新版本软件安装包的第二分块映射文件;
通过比对所述第一分块映射文件和所述第二分块映射文件,确定对所述第二分块映射文件中各数据块的操作模式;所述第一分块映射文件和所述第二分块映射文件均包括多个所述数据块对应的数据指纹信息;
根据所述操作模式构建新的软件安装包。
在一种可能的实现方式中,所述数据指纹信息包括数据块的大小、哈希值以及偏移值的至少一种。
在一种可能的实现方式中,所述通过比对所述第一分块映射文件和所述第二分块映射文件,确定对所述第二分块映射文件中各数据块的操作模式,包括:
依次比对所述第一分块映射文件和所述第二分块映射文件中各所述数据块的哈希值和/或大小;
根据比对结果确定对所述第二分块映射文件中各数据块的操作模式。
在一种可能的实现方式中,所述操作模式包括复制操作和下载操作。
在一种可能的实现方式中,所述根据比对结果确定对所述第二分块映射文件中各数据块的操作模式,包括:
当所述第一分块映射文件中数据块的哈希值和/或大小与所述第二分块映射文件中对应的所述数据块的哈希值和/或大小相同时,确定所述操作模式为复制操作;所述复制操作是从本地复制相同的数据块;
当所述第一分块映射文件中数据块的哈希值和/或大小与所述第二分块映射文件中对应的所述数据块的哈希值和/或大小不相同时,确定所述操作模式为下载操作;所述下载操作是从服务器下载不相同的数据块。
在一种可能的实现方式中,所述获取本地软件安装包的第一分块映射文件,包括:
从本地存储器获取本地软件安装包的第一分块映射文件;或者,
从服务器获取本地软件安装包的第一分块映射文件;
所述获取最新版本软件安装包的第二分块映射文件,包括:
从所述服务器获取最新版本软件安装包的第二分块映射文件。
本发明的第三方面提供一种服务器,包括:
获取模块,用于获取最新版本软件安装包;
划分模块,用于将所述软件安装包划分为多个不同大小的数据块;
所述获取模块,还用于获取各所述数据块对应的数据指纹信息,生成所述软件安装包的分块映射文件;
存储模块,用于将所述软件安装包、所述分块映射文件以及所述软件安装包的版本信息文件存储在服务器的数据库中。
本发明的第四方面提供一种终端设备,包括:
获取模块,用于获取本地软件安装包的第一分块映射文件和最新版本软件安装包的第二分块映射文件;
确定模块,用于通过比对所述第一分块映射文件和所述第二分块映射文件,确定对所述第二分块映射文件中各数据块的操作模式;所述第一分块映射文件和所述第二分块映射文件多个所述数据块对应的数据指纹信息;
构建模块,用于根据所述操作模式构建新的软件安装包。
本发明的第五方面提供一种服务器,包括:
存储器;
处理器;以及
计算机程序;
其中,所述计算机程序存储在所述存储器中,并被配置为由所述处理器执行以实现如本发明第一方面任一项所述的软件更新方法。
本发明的第六方面提供一种终端设备,包括:
存储器;
处理器;以及
计算机程序;
其中,所述计算机程序存储在所述存储器中,并被配置为由所述处理器执行以实现如本发明第二方面任一项所述的软件更新方法。
本发明的第七方面提供一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行以实现如本发明第一方面任一项或者本发明第二方面任一项所述的软件更新方法。
本发明实施例提供一种软件更新方法、装置及存储介质,服务器获取最新版本软件安装包,将软件安装包划分为多个不同大小的数据块,获取各数据块对应的数据指纹信息,生成软件安装包的分块映射文件,将软件安装包、分块映射文件以及软件安装包的版本信息文件存储在服务器的数据库中,以便客户端根据不同版本软件安装包的分块映射文件确定最新版本软件安装包中各数据块的操作模式,并根据操作模式构建新的软件安装包。上述方法解决了不相邻软件版本更新效率低的问题,提高了软件增量更新效率。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作一简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的软件更新系统的架构示意图;
图2为本发明一实施例提供的软件更新方法的流程示意图;
图3为本发明实施例提供的分块映射文件的创建示意图;
图4为本发明实施例提供的固定滑动窗口的示意图;
图5为本发明另一实施例提供的软件更新方法的流程示意图;
图6为本发明一实施例提供的服务器的结构示意图;
图7为本发明一实施例提供的终端设备的结构示意图;
图8为本发明一实施例提供的服务器的硬件结构示意图;
图9为本发明一实施例提供的终端设备的硬件结构示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本发明的实施例能够以除了在这里图示或描述的那些以外的顺序实施。
应当理解,本文中使用的术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
图1为本发明实施例提供的软件更新系统的架构示意图,如图1所示,该系统包括:服务器和至少一个客户端,其中,服务器是用于向客户端提供软件安装包下载资源的电子设备,客户端可以是通过访问服务器下载感兴趣的软件安装包的终端设备,该终端设备包括但不限于是电脑、手机、IPAD等。
具体的,开发人员定期更新服务器上各软件安装包,用户可以选择性地对终端设备上安装的软件进行版本升级。一种可能的应用场景中,服务器接收其中一个客户端发送的软件更新请求,根据软件更新请求向客户端发送最新版本的软件安装包;另一种可能的应用场景中,服务器获取到最新版本的软件安装包之后,向各客户端发送版本更新通知,客户端根据用户需求确定是否要更新软件。第一种应用场景属于客户端主动发起软件更新,第二种应用场景属于客户端被动接收软件更新,其中第二种应用场景下,部分用户可能选择不更新软件,这就造成部分客户端本地软件版本与服务器当前软件版本为不相邻的软件版本。
目前的增量更新方案中,如bsdiff/bspatch方法:
服务器端计算新版本软件与老版本软件之间的差异,得到delta文件;客户端接收delta文件,根据delta文件在老版本的基础上进行更新,得到新版本软件执行安装。虽然只是下载部分增量,但是一个patch只能作用于相邻的软件版本,如果客户端安装的软件版本与服务器端最新的软件版本不相邻,则需要服务器打包多个patch来应对当前版本与最新版本的差异,这样就使得打包过程非常繁琐,同时客户端根据多个patch合成最新版本软件的过程将非常耗时。
本发明实施例提供的软件更新方法提出一种新的基于内容分块的软件增量更新方式,解决了现有技术中增量更新中不相邻版本间需要单独打patch的问题,仅需要下载小部分增量文件,就可以构造出新版本的安装包,达到软件快速更新、下载占用带宽小的目的。
下面以具体地实施例对本发明的技术方案进行详细说明。下面这几个具体的实施例可以相互结合,对于相同或相似的概念或过程可能在某些实施例不再赘述。
图2为本发明一实施例提供的软件更新方法的流程示意图,图3为本发明实施例提供的分块映射文件的创建示意图,图4为本发明实施例提供的固定滑动窗口的示意图。
本实施例提供的软件更新方法的执行主体为服务器,如图2所示,本实施例提供的方法包括如下步骤:
S101、获取最新版本软件安装包;
软件产品的开发人员在完成软件开发后,将软件安装包发送至服务器,以便不同客户端通过服务器下载软件安装包。开发人员定期向服务器上传更新后的软件安装包,服务器将更新后的软件安装包存储在服务器的数据库中。
S102、将软件安装包划分为多个不同大小的数据块;
服务器除了存储不同版本软件安装包之外,还对不同版本软件安装包进行特殊处理,生成软件安装包对应的分块映射文件。
具体来说,对于步骤101中获取到的最新版本的软件安装包,服务器采用rabin-fingerprinting算法将软件安装包划分为长度大小不等的数据块,如图3所示。
算法的执行过程如下:
1、根据固定滑动窗口计算固定滑动窗口内的软件安装包的哈希值,若哈希值与预设基准值匹配,则将窗口位置作为数据块的边界,创建软件安装包的一个数据块;
2、继续执行步骤1直至将软件安装包划分完毕,得到多个不同大小的数据块。
参见图4,Rabin-fingerprinting预先定义两个基准值,分别为D和r。假设固定滑动窗口在位置1处的哈希值为f1,若f1mod D≠r,即哈希值与预设基准值不匹配,则移动固定滑动窗口;假设固定滑动窗口在位置2处的哈希值为f2,若f2mod D=r,即哈希值与预设基准值匹配,位置2为数据块的一个边界。通过上述方法将整个软件安装包划分为多个不同大小的数据块。
需要指出的是,固定滑动窗口在移动过程中,存在一种可能的情况,固定滑动窗口的哈希值一直无法与预设的两个基准值匹配,为了避免该情况的发生,需要预设数据块长度的最大阈值,若固定滑动窗口的移动距离达到最大阈值,则直接进行强制分块。
S103、获取各数据块对应的数据指纹信息,生成软件安装包的分块映射文件;
服务器获取各数据块对应的数据指纹信息,其中数据指纹信息包括数据块的大小、哈希值以及偏移值的至少一种。数据块的哈希值用于唯一标识数据块,数据块的大小用于指示数据块的长度,各数据块的偏移值用于指示各数据块在软件安装包的偏移位置。
如图3中各数据块对应的数据结构就是按照划分顺序排列的,服务器根据各数据块的划分顺序,对各数据块对应的数据指纹信息进行序列化处理,得到软件安装包的分块映射文件。
其中,分块映射文件中包括软件安装包分割成不同大小的数据块对应的数据指纹信息,各数据块的大小存储在sizes数组中,各数据块的哈希值存储在hashes数组中,sizes数组中数据块的大小是与hashes数组中数据块的哈希值一一对应的,例如,sizes数组中的第n项数据块的大小与hashes数组中的第n项哈希值对应。
由图3可知,sizes数组和hashes数组中的元素顺序与软件安装包的内容顺序是一致的,可见各数据块的偏移值可以根据sizes数组推导出来的,例如,第n个数据块在软件安装包中的偏移值为sizes数组中前n-1个数据块大小之和。
S104、将软件安装包、分块映射文件以及软件安装包的版本信息文件存储在服务器的数据库中。
本发明实施例提供的软件更新方法,服务器获取最新版本软件安装包,将软件安装包划分为多个不同大小的数据块,获取各数据块对应的数据指纹信息,生成软件安装包的分块映射文件,将软件安装包、分块映射文件以及软件安装包的版本信息文件存储在服务器的数据库中,以便客户端进行软件更新。通过上述方法生成不同版本软件安装包的分块映射文件,以便客户端进行不相邻软件版本的更新,提高软件增量更新效率,减小更新占用的网络带宽。
图5为本发明另一实施例提供的软件更新方法的流程示意图,本实施例提供的方法的执行主体为客户端,如图5所示,本实施提供的方法包括如下步骤:
S201、获取本地软件安装包的第一分块映射文件和最新版本软件安装包的第二分块映射文件;
本实施例中,客户端在本地安装的软件的当前版本与服务器上该软件的最新版本为相邻版本或者不相邻版本。本实施例提供的方法可以用于处理相邻版本的软件更新,也可以用于处理不相邻版本的软件更新。
一种可能的应用场景中,客户端向服务器发送软件版本请求,软件版本请求用于指示服务器发送软件安装包最新的版本信息文件,客户端在接收到服务器发送的软件安装包的版本信息文件后,与本地保存的软件安装包的版本信息文件进行比对,若版本信息文件不同,则客户端确定软件安装包在服务器上已更新版本。若用户希望将客户端的安装的软件更新到最新版本,则向服务器发起软件更新请求。
另一种可能的应用场景中,服务器创建软件安装包的最新版本之后,向客户端发送软件版本更新通知,若用户希望将客户端的安装的软件更新到最新版本,则向服务器发起软件更新请求。
在客户端向服务器发起软件更新请求后,获取本地软件安装包的第一分块映射文件和最新版本软件安装包的第二分块映射文件。软件安装包的分块映射文件中包括将软件安装包分割成不同大小的数据块对应的数据指纹信息。其中,数据指纹信息包括数据块的大小、哈希值以及偏移值的至少一种。
需要指出的是,分块映射文件是在服务器创建软件安装包时生成的,与软件安装包、软件安装包的版本信息文件一起保存在服务器的数据库中。
其中,版本信息文件用于记录软件安装包当前版本的相关信息,客户端可以根据版本信息文件检测是否有最新版本以及对软件安装包的校验,本版文件通常采用YML格式来表示各字段,主要的字段信息:
当前软件的最新版本;
当前最新版本软件的SHA值;
当前软件版本的发布日期;
当前软件的大小;
当前软件的名称。
需要指出的是,服务器上的软件安装包的版本信息文件采用覆盖式存储,即服务器上仅保存软件安装包最新的版本信息文件,老版本软件安装包的版本信息文件会被新的版本信息文件替换。
客户端在服务器上下载某软件时,可以只下载软件安装包,也可以在下载软件安装包的同时,下载该软件安装包的分块映射文件以及版本信息文件。
客户端获取本地软件安装包的第一分块映射文件包括如下两种实现方式:
一种可能的实现方式中,客户端从本地存储器获取本地软件安装包的第一分块映射文件;另一种可能的实现方式中,客户端从服务器获取本地软件安装包的第一分块映射文件。
客户端获取最新版本软件安装包的第二分块映射文件具体是,从服务器获取最新版本软件安装包的第二分块映射文件。
S202、通过比对第一分块映射文件和第二分块映射文件,确定对第二分块映射文件中各数据块的操作模式;
其中,第一分块映射文件和第二分块映射文件均包括多个数据块对应的数据指纹信息。
客户端在获取第一分块映射文件和第二分块映射文件之后,依次比对第一分块映射文件和第二分块映射文件中各数据块的哈希值和/或大小,确定对第二分块映射文件中各数据块的操作模式。具体的比对方式如下:
客户端以最新版本软件安装包的第二分块映射文件中各数据块的哈希值和/或大小进行遍历,在本地软件安装包的第一分块映射文件中查找对应数据块的哈希值和/或大小,若两个文件对应偏移位置的数据块的哈希值和/或大小均相同,说明该数据块已存在于客户端本地软件安装包中,该数据块对应的操作模式为复制操作,直接从本地复制该数据块;若两个文件对应偏移位置的数据块的哈希值和/或大小不同,说明该数据块不存在本地,该数据块对应的操作模式为下载模式,客户端需要从服务器下载该数据块。
S203、根据操作模式构建新的软件安装包。
客户端通过比对第一分块映射文件和第二分块映射文件,确定第二分块映射文件相对于第一分块映射文件数据块哈希值和/或大小发生变化的数据块集合以及数据块哈希值和/或大小未发生变化的数据块集合。客户端对发生变化的数据块执行下载操作,对未发生变化的数据块执行复制操作。
具体的,客户端从服务器下载发生变化的数据块,从本地存储器中复制未发生变化的数据块,并根据各数据块的偏移值构建新的软件安装包。其中客户端采用http range请求从服务器分块下载发生变化的数据块。
客户端根据下载的新增的数据块和/或修改的数据块,以及未发生变化的数据块构建新的软件安装包,将新的软件安装包、以及与新的软件安装包对应的第二分块映射文件和软件安装包的、版本信息文件存储在客户端的本地存储器中。可选的,客户端同时将新的软件安装包、版本信息文件以及与新的软件安装包对应的第二分块映射文件存储在客户端的本地存储器中,以便客户端在下一次软件更新时,直接从本地存储器中获取当前软件安装包的分块映射文件,提高客户端软件更新的速率。
本发明实施例提供的软件更新方法,客户端获取本地软件安装包的第一分块映射文件和最新版本软件安装包的第二分块映射文件,其中第一分块映射文件和第二分块映射文件均包括多个数据块对应的数据指纹信息,通过比对第一分块映射文件和第二分块映射文件,确定对最新版本软件安装包中各数据块的操作模式,并根据操作模式构建新的软件安装包。上述方法解决了不相邻软件版本更新效率低的问题,提高了软件增量更新效率,且占用的网络带宽小。
图6为本发明一实施例提供的服务器的结构示意图,如图6所示,本实施例提供的服务器300包括:
获取模块301,用于获取最新版本软件安装包;
划分模块302,用于将所述软件安装包划分为多个不同大小的数据块;
所述获取模块301,还用于获取各所述数据块对应的数据指纹信息,生成模块303,用于生成所述软件安装包的分块映射文件;
存储模块304,用于将所述软件安装包、所述分块映射文件以及所述软件安装包的版本信息文件存储在服务器的数据库中。
本实施例提供的服务器,可用于执行如图2所示的软件更新方法,其实现原理和技术效果类似,此处不再赘述。
可选的,所述划分模块302,具体用于:
根据固定滑动窗口计算所述固定滑动窗口内的软件安装包的哈希值,若所述哈希值与预设基准值匹配,则创建所述软件安装包的一个数据块;
通过上述步骤将所述软件安装包划分为多个不同大小的数据块。
可选的,所述生成模块303,具体用于:
根据各所述数据块的划分顺序,对各所述数据块对应的数据指纹信息进行序列化处理,得到所述软件安装包的分块映射文件。
可选的,所述数据指纹信息包括数据块的大小、哈希值以及偏移值的至少一种。
本实施例提供的服务器,可以执行上述方法实施例服务器对应的技术方案,其实现原理和技术效果类似,此处不再赘述。
图7为本发明一实施例提供的终端设备的结构示意图,如图7所示,本实施例提供的终端设备400,包括:
获取模块401,用于获取本地软件安装包的第一分块映射文件和最新版本软件安装包的第二分块映射文件;
确定模块402,用于通过比对所述第一分块映射文件和所述第二分块映射文件,确定对所述第二分块映射文件中各数据块的操作模式;所述第一分块映射文件和所述第二分块映射文件均包括多个所述数据块对应的数据指纹信息;
构建模块403,用于根据所述操作模式构建新的软件安装包。
本实施例提供的终端设备,可用于执行如图5所示的软件更新方法,其实现原理和技术效果类似,此处不再赘述。
可选的,所述数据指纹信息包括数据块的大小、哈希值以及偏移值的至少一种。
可选的,所述确定模块402,具体用于:
依次比对所述第一分块映射文件和所述第二分块映射文件中各所述数据块的哈希值和/或大小;
根据比对结果确定对所述第二分块映射文件中各数据块的操作模式。
可选的,所述操作模式包括复制操作和下载操作。
可选的,所述确定模块402,具体用于:
当所述第一分块映射文件中数据块的哈希值和/或大小与所述第二分块映射文件中对应的所述数据块的哈希值和/或大小相同时,确定所述操作模式为复制操作;
当所述第一分块映射文件中数据块的哈希值和/或大小与所述第二分块映射文件中对应的所述数据块的哈希值和/或大小不相同时,确定所述操作模式为下载操作。可选的,所述获取模块401,具体用于:
从本地存储器获取本地软件安装包的第一分块映射文件;或者,
从服务器获取本地软件安装包的第一分块映射文件;
所述获取模块401,具体用于:
从所述服务器获取最新版本软件安装包的第二分块映射文件。
本实施例提供的终端设备,可以执行上述方法实施例终端设备对应的技术方案,其实现原理和技术效果类似,此处不再赘述。
图8为本发明一实施例提供的服务器的硬件结构示意图,如图8所示,本实施例的服务器500,包括:
存储器501;
处理器502;以及
计算机程序;
其中,计算机程序存储在存储器501中,并被配置为由处理器502执行以实现如前述任一项方法实施例的技术方案,其实现原理和技术效果类似,此处不再赘述。
可选的,存储器501既可以是独立的,也可以跟处理器502集成在一起。
当存储器501是独立于处理器502之外的器件时,服务器500还包括:
总线503,用于连接存储器501和处理器502。
本发明实施例还提供一种计算机可读存储介质,其上存储有计算机程序,计算机程序被处理器502执行以实现如上方法实施例中服务器500所执行的各个步骤。
图9为本发明一实施例提供的终端设备的硬件结构示意图,如图8所示,本实施例的终端设备600,包括:
存储器601;
处理器602;以及
计算机程序;
其中,计算机程序存储在存储器601中,并被配置为由处理器602执行以实现如前述任一项方法实施例的技术方案,其实现原理和技术效果类似,此处不再赘述。
可选的,存储器601既可以是独立的,也可以跟处理器602集成在一起。
当存储器601是独立于处理器602之外的器件时,终端设备600还包括:
总线603,用于连接存储器601和处理器602。
本发明实施例还提供一种计算机可读存储介质,其上存储有计算机程序,计算机程序被处理器602执行以实现如上方法实施例中终端设备600所执行的各个步骤。
在本发明所提供的几个实施例中,应该理解到,所揭露的设备和方法,可以通过其它的方式实现。例如,以上所描述的设备实施例仅仅是示意性的,例如,模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个模块可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或模块的间接耦合或通信连接,可以是电性,机械或其它的形式。
作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个模块单独物理存在,也可以两个或两个以上模块集成在一个单元中。上述模块成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
上述以软件功能模块的形式实现的集成的模块,可以存储在一个计算机可读取存储介质中。上述软件功能模块存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)或处理器(英文:processor)执行本申请各个实施例方法的部分步骤。
应理解,上述处理器可以是中央处理单元(英文:Central Processing Unit,简称:CPU),还可以是其他通用处理器、数字信号处理器(英文:Digital Signal Processor,简称:DSP)、专用集成电路(英文:Application Specific Integrated Circuit,简称:ASIC)等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合发明所公开的方法的步骤可以直接体现为硬件处理器执行完成,或者用处理器中的硬件及软件模块组合执行完成。
存储器可能包含高速RAM存储器,也可能还包括非易失性存储NVM,例如至少一个磁盘存储器,还可以为U盘、移动硬盘、只读存储器、磁盘或光盘等。
总线可以是工业标准体系结构(Industry Standard Architecture,ISA)总线、外部设备互连(Peripheral Component,PCI)总线或扩展工业标准体系结构(ExtendedIndustry Standard Architecture,EISA)总线等。总线可以分为地址总线、数据总线、控制总线等。为便于表示,本申请附图中的总线并不限定仅有一根总线或一种类型的总线。
上述存储介质可以是由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。存储介质可以是通用或专用计算机能够存取的任何可用介质。
一种示例性的存储介质耦合至处理器,从而使处理器能够从该存储介质读取信息,且可向该存储介质写入信息。当然,存储介质也可以是处理器的组成部分。处理器和存储介质可以位于专用集成电路(Application Specific Integrated Circuits,简称:ASIC)中。当然,处理器和存储介质也可以作为分立组件存在于电子设备或主控设备中。
最后应说明的是:以上各实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述各实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的范围。
Claims (15)
1.一种软件更新方法,其特征在于,包括:
获取最新版本软件安装包;
将所述软件安装包划分为多个不同大小的数据块;
获取各所述数据块对应的数据指纹信息,生成所述软件安装包的分块映射文件;
将所述软件安装包、所述分块映射文件以及所述软件安装包的版本信息文件存储在服务器的数据库中。
2.根据权利要求1所述的方法,其特征在于,所述将所述软件安装包划分为多个数据块,包括:
根据固定滑动窗口计算所述固定滑动窗口内的软件安装包的哈希值,若所述哈希值与预设基准值匹配,则创建所述软件安装包的一个数据块;
通过上述步骤将所述软件安装包划分为多个不同大小的数据块。
3.根据权利要求1所述的方法,其特征在于,所述生成所述软件安装包的分块映射文件,包括:
根据各所述数据块的划分顺序,对各所述数据块对应的数据指纹信息进行序列化处理,得到所述软件安装包的分块映射文件。
4.根据权利要求1至3任一项所述的方法,其特征在于,所述数据指纹信息包括数据块的大小、哈希值以及偏移值的至少一种。
5.一种软件更新方法,其特征在于,包括:
获取本地软件安装包的第一分块映射文件和最新版本软件安装包的第二分块映射文件;
通过比对所述第一分块映射文件和所述第二分块映射文件,确定对所述第二分块映射文件中各数据块的操作模式;所述第一分块映射文件和所述第二分块映射文件均包括多个所述数据块对应的数据指纹信息;
根据所述操作模式构建新的软件安装包。
6.根据权利要求5所述的方法,其特征在于,所述数据指纹信息包括数据块的大小、哈希值以及偏移值的至少一种。
7.根据权利要求6所述的方法,其特征在于,所述通过比对所述第一分块映射文件和所述第二分块映射文件,确定对所述第二分块映射文件中各数据块的操作模式,包括:
依次比对所述第一分块映射文件和所述第二分块映射文件中各所述数据块的哈希值和/或大小;
根据比对结果确定对所述第二分块映射文件中各数据块的操作模式。
8.根据权利要求7所述的方法,其特征在于,所述操作模式包括复制操作和下载操作。
9.根据权利要求8所述的方法,其特征在于,所述根据比对结果确定对所述第二分块映射文件中各数据块的操作模式,包括:
当所述第一分块映射文件中数据块的哈希值和/或大小与所述第二分块映射文件中对应的所述数据块的哈希值和/或大小相同时,确定所述操作模式为复制操作;所述复制操作是从本地复制相同的数据块;
当所述第一分块映射文件中数据块的哈希值和/或大小与所述第二分块映射文件中对应的所述数据块的哈希值和/或大小不相同时,确定所述操作模式为下载操作;所述下载操作是从服务器下载不相同的数据块。
10.根据权利要求5所述的方法,其特征在于,所述获取本地软件安装包的第一分块映射文件,包括:
从本地存储器获取本地软件安装包的第一分块映射文件;或者,
从服务器获取本地软件安装包的第一分块映射文件;
所述获取最新版本软件安装包的第二分块映射文件,包括:
从所述服务器获取最新版本软件安装包的第二分块映射文件。
11.一种服务器,其特征在于,包括:
获取模块,用于获取最新版本软件安装包;
划分模块,用于将所述软件安装包划分为多个不同大小的数据块;
所述获取模块,还用于获取各所述数据块对应的数据指纹信息,生成所述软件安装包的分块映射文件;
存储模块,用于将所述软件安装包、所述分块映射文件以及所述软件安装包的版本信息文件存储在服务器的数据库中。
12.一种终端设备,其特征在于,包括:
获取模块,用于获取本地软件安装包的第一分块映射文件和最新版本软件安装包的第二分块映射文件;
确定模块,用于通过比对所述第一分块映射文件和所述第二分块映射文件,确定对所述第二分块映射文件中各数据块的操作模式;所述第一分块映射文件和所述第二分块映射文件均包括多个所述数据块对应的数据指纹信息;
构建模块,用于根据所述操作模式构建新的软件安装包。
13.一种服务器,其特征在于,包括:
存储器;
处理器;以及
计算机程序;
其中,所述计算机程序存储在所述存储器中,并被配置为由所述处理器执行以实现如权利要求1至4任一项所述的软件更新方法。
14.一种终端设备,其特征在于,包括:
存储器;
处理器;以及
计算机程序;
其中,所述计算机程序存储在所述存储器中,并被配置为由所述处理器执行以实现如权利要求5至10任一项所述的软件更新方法。
15.一种计算机可读存储介质,其特征在于,其上存储有计算机程序,所述计算机程序被处理器执行以实现如权利要求1至4任一项或者权利要求5至10任一项所述的软件更新方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910286174.1A CN110032383A (zh) | 2019-04-08 | 2019-04-08 | 软件更新方法、装置及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910286174.1A CN110032383A (zh) | 2019-04-08 | 2019-04-08 | 软件更新方法、装置及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN110032383A true CN110032383A (zh) | 2019-07-19 |
Family
ID=67237945
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910286174.1A Pending CN110032383A (zh) | 2019-04-08 | 2019-04-08 | 软件更新方法、装置及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110032383A (zh) |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110134409A (zh) * | 2019-04-12 | 2019-08-16 | 宁波麦度智联科技股份有限公司 | 一种程序的烧录优化方法 |
CN112463177A (zh) * | 2020-12-11 | 2021-03-09 | 百富计算机技术(深圳)有限公司 | 一种软件的更新包的生成方法 |
CN112882746A (zh) * | 2021-02-03 | 2021-06-01 | 网易(杭州)网络有限公司 | 应用程序的更新方法、装置、存储介质及计算机设备 |
CN113377424A (zh) * | 2021-06-23 | 2021-09-10 | 支付宝(杭州)信息技术有限公司 | 一种安装包处理方法、装置以及设备 |
CN114006898A (zh) * | 2021-10-30 | 2022-02-01 | 杭州迪普信息技术有限公司 | 版本更换方法、装置及系统 |
CN114138291A (zh) * | 2020-09-03 | 2022-03-04 | 网神信息技术(北京)股份有限公司 | 软件运行参数动态设置方法、装置、电子设备及存储介质 |
CN114217870A (zh) * | 2021-12-10 | 2022-03-22 | 北京欧珀通信有限公司 | 安装包的加载方法及装置、电子设备、存储介质 |
CN114840231A (zh) * | 2022-04-07 | 2022-08-02 | 重庆金康赛力斯新能源汽车设计院有限公司 | 一种程序包的验算方法、系统、计算机设备和存储介质 |
CN115543688A (zh) * | 2022-09-29 | 2022-12-30 | 广州鼎甲计算机科技有限公司 | 备份方法、装置、代理端和存储介质 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103729225A (zh) * | 2014-01-22 | 2014-04-16 | 中国人民解放军国防科学技术大学 | 一种基于内容分块的远程文件实时更新方法 |
CN106528125A (zh) * | 2016-10-26 | 2017-03-22 | 腾讯科技(深圳)有限公司 | 一种数据文件的增量更新方法和服务器、客户端以及系统 |
US20180095993A1 (en) * | 2008-04-25 | 2018-04-05 | Vmware, Inc. | Updating a file using sync directories |
-
2019
- 2019-04-08 CN CN201910286174.1A patent/CN110032383A/zh active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20180095993A1 (en) * | 2008-04-25 | 2018-04-05 | Vmware, Inc. | Updating a file using sync directories |
CN103729225A (zh) * | 2014-01-22 | 2014-04-16 | 中国人民解放军国防科学技术大学 | 一种基于内容分块的远程文件实时更新方法 |
CN106528125A (zh) * | 2016-10-26 | 2017-03-22 | 腾讯科技(深圳)有限公司 | 一种数据文件的增量更新方法和服务器、客户端以及系统 |
Non-Patent Citations (1)
Title |
---|
FUKAN: "【转】基于内容可变长度分块(CDC)", 《公开网址:HTTPS://WWW.CNBLOGS.COM/HADIS-YUKI/P/5224225.HTML》 * |
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110134409A (zh) * | 2019-04-12 | 2019-08-16 | 宁波麦度智联科技股份有限公司 | 一种程序的烧录优化方法 |
CN114138291A (zh) * | 2020-09-03 | 2022-03-04 | 网神信息技术(北京)股份有限公司 | 软件运行参数动态设置方法、装置、电子设备及存储介质 |
CN112463177A (zh) * | 2020-12-11 | 2021-03-09 | 百富计算机技术(深圳)有限公司 | 一种软件的更新包的生成方法 |
WO2022121505A1 (zh) * | 2020-12-11 | 2022-06-16 | 百富计算机技术(深圳)有限公司 | 一种软件的更新包的生成方法 |
CN112463177B (zh) * | 2020-12-11 | 2024-08-13 | 百富计算机技术(深圳)有限公司 | 一种软件的更新包的生成方法 |
CN112882746A (zh) * | 2021-02-03 | 2021-06-01 | 网易(杭州)网络有限公司 | 应用程序的更新方法、装置、存储介质及计算机设备 |
CN112882746B (zh) * | 2021-02-03 | 2023-07-07 | 网易(杭州)网络有限公司 | 应用程序的更新方法、装置、存储介质及计算机设备 |
CN113377424A (zh) * | 2021-06-23 | 2021-09-10 | 支付宝(杭州)信息技术有限公司 | 一种安装包处理方法、装置以及设备 |
CN114006898A (zh) * | 2021-10-30 | 2022-02-01 | 杭州迪普信息技术有限公司 | 版本更换方法、装置及系统 |
CN114217870A (zh) * | 2021-12-10 | 2022-03-22 | 北京欧珀通信有限公司 | 安装包的加载方法及装置、电子设备、存储介质 |
CN114840231A (zh) * | 2022-04-07 | 2022-08-02 | 重庆金康赛力斯新能源汽车设计院有限公司 | 一种程序包的验算方法、系统、计算机设备和存储介质 |
CN115543688A (zh) * | 2022-09-29 | 2022-12-30 | 广州鼎甲计算机科技有限公司 | 备份方法、装置、代理端和存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110032383A (zh) | 软件更新方法、装置及存储介质 | |
US10025528B2 (en) | Managing transformations of snapshots in a storage system | |
CN111492354B (zh) | 不可变存储装置中的数据库元数据 | |
US9940122B2 (en) | Dynamic data difference generation and distribution | |
US20190196805A1 (en) | Controlled rollout of updates for applications installed on client devices | |
US8087017B1 (en) | Trace-assisted prefetching of virtual machines in a distributed system | |
US20200201821A1 (en) | Synchronization of index copies in an lsm tree file system | |
US20130054531A1 (en) | Database cloning | |
JP2004501451A (ja) | ファイル差分を使用するファイル送信システムおよび方法 | |
JP2018511884A (ja) | モバイルデバイス上の自動的なクラウドベースの全データバックアップおよびリストアのためのシステムおよび方法 | |
US10346256B1 (en) | Client side cache for deduplication backup systems | |
KR102098415B1 (ko) | 캐시 관리 기법 | |
EP3803626A1 (en) | Distributed data synchronization in a distributed computing system | |
EP3449372B1 (en) | Fault-tolerant enterprise object storage system for small objects | |
CN102541593A (zh) | 一种远程文件的版本快速比对方法 | |
CN114461217A (zh) | 代码编译方法、装置、电子设备及存储介质 | |
CN113434122A (zh) | 多角色页面创建方法、装置、服务器及可读存储介质 | |
CN105847364A (zh) | 基于统一域名的公有云对象存储方法及系统 | |
KR101718739B1 (ko) | 이기종 하둡을 위한 동적 데이터 복제 시스템 및 방법 | |
JP2016099659A (ja) | 管理装置、ストレージシステム、ストレージ管理方法、及びプログラム | |
WO2017158663A1 (ja) | データ生成装置、組込端末、ファームウェア更新システム及びデータ生成方法 | |
CN117971297B (zh) | 依赖包同步方法、装置、计算机设备和存储介质 | |
CN116800733B (zh) | 一种差分包的下载方法及服务器 | |
US10747729B2 (en) | Device specific chunked hash size tuning | |
CN109299067A (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 | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20190719 |