本发明涉及电子技术领域,尤其涉及一种数据备份方法及装置。
背景技术:
智能终端(比如智能手机等)的普及率迅速增长使之成为现代生活中的必需品。日常生活中,随着用户使用智能终端处理事务越来越多,智能终端中可能存储有比较重要的数据。为了避免这些数据的信息丢失,通常需要将这些数据进行备份。
目前,在信息备份过程中,容易因为网络或其他问题出现备份中断,影响数据备份的效率。
技术实现要素:
本发明实施例提供一种数据备份方法及装置,可以提高数据备份的效率。
第一方面,本发明实施例提供一种数据备份方法,包括:
在将目标数据序列备份至云服务器的过程中,若在备份所述目标数据序列中的数据i的过程中发生中断,则将所述数据i的备份起始点记录为中断节点,所述目标数据序列由多个数据组成;
当所述目标数据序列恢复备份时,根据所述中断节点继续将所述目标数据序列备份至所述云服务器。
第二方面,本发明实施例提供了一种数据备份装置,包括:
记录模块,用于在将目标数据序列备份至云服务器的过程中,若在备份所述目标数据序列中的数据i的过程中发生中断,则将所述数据i的备份起始点记录为中断节点,所述目标数据序列由多个数据组成;
备份模块,用于当所述目标数据序列恢复备份时,根据所述中断节点继续将所述目标数据序列备份至所述云服务器。
第三方面,本发明实施例提供了一种计算机设备,包括存储器,处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现本发明实施例第一方面中所描述的部分或全部步骤。
第四方面,本发明提供一种计算机存储介质,所述计算机可读存储媒介上存储有计算机程序(指令),所述程序(指令)被处理器执行时实现本发明实施例第一方面中所描述的部分或全部步骤。
本发明实施例中,在将目标数据序列备份至云服务器的过程中,若在备份数据序列中的数据i的过程中发生中断,则将数据i的备份起始点记录为中断节点,后续目标数据序列恢复备份时,直接根据该中断节点继续将目标数据序列备份至云服务器即可,无需重新进行数据备份,进而提高数据备份的效率。
本发明的这些方面或其他方面在以下实施例的描述中会更加简明易懂。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的一种通信系统的示意图;
图2为本发明一实施例提供的一种数据备份方法的流程示意图;
图3为本发明一实施例提供的一种数据备份方法的流程示意图;
图4为本发明一实施例提供的一种数据备份装置的结构示意图;
图5为本发明一实施例提供的一种计算机设备的结构示意图;
图6为本发明一实施例提供的一种终端设备的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
以下分别进行详细说明。
本发明的说明书和权利要求书及所述附图中的术语“第一”、“第二”、“第三”和“第四”等是用于区别不同对象,而不是用于描述特定顺序。此外,术语“包括”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或单元的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可选地还包括没有列出的步骤或单元,或可选地还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本发明的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其它实施例相结合。
以下,对本申请中的部分用语进行解释说明,以便于本领域技术人员理解。
1)终端设备,又称之为用户设备(User Equipment,UE),是一种向用户提供语音和/或数据连通性的设备,例如,具有无线连接功能的手持式设备、车载设备等。常见的终端例如包括:手机、平板电脑、笔记本电脑、掌上电脑、移动互联网设备(mobile internet device,MID)、可穿戴设备,例如智能手表、智能手环、计步器等。
2)云服务器,通常是指运行在相同的物理硬件上的“虚拟”服务器,云服务器作为物理服务器来使用。虚拟服务器平台上,管理员可以用具体的CPU、内存和磁盘特性提供服务器,这些云服务器系统都通过在线方式提供。云提供商提供的系统由于功能和价格的不同也有不同的“规格”。云服务器这种产品通常有两个关键维度:CPU和内存。基本上来说,云服务器小型规格为1vCPU和2GB RAM;云服务器中型规格为2vCPU和4GB RAM;云服务器大型规格为4vCPU和8GB RAM。云计算对于云服务器本身的结构灵活性、计算密度、存储容量等有一定的要求。
3)并行执行是在两条线程上分别执行动作A与动作B,比如,在第一线程上执行动作A,在第二线程上执行动作B,二者可以是同时进行的,也可以是在执行一个动作的过程中执行另一动作。
4)“多个”是指两个或两个以上。“和/或”,描述关联对象的关联关系,表示可以存在三种关系,例如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。字符“/”一般表示前后关联对象是一种“或”的关系。
下面结合附图对本申请的实施例进行描述。
请参阅图1,图1是本发明实施例公开的一种通信系统的示意图。图1所示的通信系统包括数据备份装置(图1以终端设备110表示)和云服务器120,其中,在终端设备110将目标数据序列备份至云服务器120的过程中,若在所述备份数据序列中的数据i的过程中发生中断,则终端设备110将数据i的备份起始点记录为中断节点;后续目标数据序列恢复备份时,终端设备110根据该中断节点继续将目标数据序列备份至云服务器120即可,无需重新进行数据备份,进而提高数据备份的效率。
请参见图2,图2为本发明实施例提供的一种数据备份方法的流程示意图,其中,以下执行本发明的数据备份方法的主体数据备份装置以终端设备为例进行说明,包括以下步骤:
S201、在终端设备将目标数据序列备份至云服务器的过程中,若在备份所述目标数据序列中的数据i的过程中发生中断,则所述终端设备将所述数据i的备份起始点记录为中断节点,所述目标数据序列由多个数据组成。
S202、当所述目标数据序列恢复备份时,所述终端设备根据所述中断节点继续将所述目标数据序列备份至所述云服务器。
举例来说,假设目标数据序列是由3个数据组成的数据序列(比如数据1-数据2-数据3),当在备份数据2的过程中发生中断,此时为了避免因在数据2的中途再给数据2进行备份而容易导致某些数据丢失的问题,本方案将数据2的备份起始点记录为中断节点,也就是说,后续终端设备继续为目标数据集进行备份时,从数据2开始进行备份即可,无需重新进行数据备份,进而提高数据备份的效率。
可选地,以上步骤S202所述终端设备根据所述中断节点继续将所述目标数据序列备份至所述云服务器的具体实施方式为:所述终端设备确定所述目标数据序列中未完全备份到所述云服务器中的所有数据;所述终端设备将所述目标数据序列中未完全备份到所述云服务器中的所有数据拆分成N个子数据集,所述N为正整数;所述终端设备将所述N个子数据集分别在N条线程上并行的备份至所述云服务器。
举例来说,假设N=2,目标数据集是由7个数据组成的数据序列(比如数据1-数据2-数据3-数据4-数据5-数据6-数据7),当在备份数据2的过程中发生中断,此时目标数据序列中未完全备份到所述云服务器中的所有数据有数据2到数据7,然后终端设备将数据2到数据7拆分成2个子数据集,然后将这2个子数据集分别在两个线程上并行的备份至云服务器。可见,将目标数据序列剩下的数据拆分成几个子数据集,然后将这几个子数据集并行进行备份,进而缩短了数据备份的时间,进而提高数据备份的效率。
可选地,所述N个子数据集包含的数据个数均小于或等于第一阈值和/或所述N个子数据集的大小均小于或等于第二阈值。
其中,第一阈值例如可以是1、2、3、6、7、10或是其他值。
其中,第二阈值例如可以是10mb、20mb、30mb、60mb、70mb、100mb或是其他值。
举例来说,假设第一阈值为2,N=3,第二阈值为30mb,目标数据序列中未完全备份到所述云服务器中的所有数据有数据2到数据7,那么3个子数据集包含的数据个数均小于或等于3和/或3个子数据集包含的数据的大小均小于或等于30mb。
可选地,若所述目标数据序列的备份发生中断的原因为网络中断,以上步骤S201所述终端设备记录所述目标数据集的中断节点之后,上述方法还包括:当所述终端设备的网络恢复连接时,所述终端设备恢复备份所述目标数据序列。
其中,网络中断为无线局域网中断,那么终端设备后续的网络恢复连接则是终端设备的无线局域网恢复连接。
举例来说,目标数据序列的备份发生中断的原因有网络中断或者服务器故障等,假设目标数据序列的备份发生中断的原因为网络中断,后续当终端设备接入无线网或移动网络时,终端设备直接恢复备份目标数据序列,无需用户手动去恢复备份目标数据序列,进而提高了用户体验。
进一步的,当所述终端设备的网络恢复连接时,终端设备先检测当前连接的网络质量是否较佳,若当前连接的网络质量较佳,则所述终端设备直接恢复备份所述目标数据序列,这样可进一步避免目标数据序列的备份再次发生中断。
可选地,所述方法还包括:
在备份所述目标数据序列的过程中,所述终端设备在所述终端设备的显示屏上显示一悬浮框,在所述悬浮框上显示的内容包括备份进度条、所述终端设备当前上传下载速度、所述终端设备当前网络的类型、所述目标数据序列的名称、所述目标数据序列的类型中的至少一种,所述备份进度条用于表示备份所述目标数据序列的进度。
其中,网络类型包括移动数据网络、无线局域网等等。
可选地,所述终端设备在所述终端设备的显示屏上显示一悬浮框之后,所述方法还包括:
在备份所述目标数据序列的过程中,当检测到针对所述备份进度条的双击操作时,所述终端设备暂停备份所述目标数据序列。
可选地,所述悬浮框处于半隐藏状态,所述方法还包括:
当检测到针对所述悬浮框的点击操作时,所述终端设备将所述悬浮框从半隐藏状态切换至全显示状态。
本发明实施例还提供了另一更为详细的方法流程,如图3所示,其中,以下执行本发明的数据备份方法的主体数据备份装置以终端设备为例进行说明,包括:
S301、终端设备将目标数据序列备份至云服务器,所述目标数据序列由多个数据组成。
S302、在终端设备将所述目标数据序列备份至云服务器的过程中,若在备份所述目标数据序列中的数据i的过程中发生中断,则所述终端设备将所述数据i的备份起始点记录为中断节点。
S303、若所述目标数据序列的备份发生中断的原因为网络中断,当所述终端设备的网络恢复连接时,所述终端设备恢复备份所述目标数据序列。
S304、所述终端设备确定所述目标数据序列中未完全备份到所述云服务器中的所有数据。
S305、所述终端设备将所述目标数据序列中未完全备份到所述云服务器中的所有数据拆分成N个子数据集,所述N为正整数,所述N个子数据集包含的数据个数均小于或等于第一阈值和/或所述N个子数据集的大小均小于或等于第二阈值。
S306、所述终端设备将所述N个子数据集分别在N条线程上并行的备份至所述云服务器。
需要说明的是,图3所示的方法的各个步骤的具体实现过程可参见上述方法所述的具体实现过程,在此不再叙述。
本发明实施例还提供了一种数据备份装置400,如图4所示,其中图4所示的数据备份装置包括终端设备,包括:
记录模块401,用于在将目标数据序列备份至云服务器的过程中,若在备份所述目标数据序列中的数据i的过程中发生中断,则将所述数据i的备份起始点记录为中断节点,所述目标数据序列由多个数据组成;
备份模块402,用于当所述目标数据序列恢复备份时,根据所述中断节点继续将所述目标数据序列备份至所述云服务器。
可选地,所述备份模块402具体用于:
确定所述目标数据序列中未完全备份到所述云服务器中的所有数据;
将所述目标数据序列中未完全备份到所述云服务器中的所有数据拆分成N个子数据集,所述N为正整数;
将所述N个子数据序列分别在N条线程上并行的备份至所述云服务器。
可选地,所述N个子数据集包含的数据个数均小于或等于第一阈值和/或所述N个子数据集的大小均小于或等于第二阈值。
可选地,若所述目标数据序列的备份发生中断的原因为网络中断,所述装置还包括:
备份恢复模块403,用于当网络恢复连接时,恢复备份所述目标数据序列。
需要说明的是,上述各模块(记录模块401、备份模块402和备份恢复模块403)用于执行上述方法的相关步骤。
在本实施例中,数据备份装置400是以模块的形式来呈现。这里的“模块”可以指特定应用集成电路(application-specific integrated circuit,ASIC),执行一个或多个软件或固件程序的处理器和存储器,集成逻辑电路,和/或其他可以提供上述功能的器件。此外,以上记录模块401、备份模块402和备份恢复模块403可通过图5所示的计算机设备的处理器501来实现。
如图5所示,计算机500可以以图5中的结构来实现,该计算机设备包括终端设备,该计算机设备500包括至少一个处理器501,至少一个存储器502以及至少一个通信接口503。所述处理器501、所述存储器502和所述通信接口503通过所述通信总线连接并完成相互间的通信。
处理器501可以是通用中央处理器(CPU),微处理器,特定应用集成电路(application-specific integrated circuit,ASIC),或一个或多个用于控制以上方案程序执行的集成电路。
通信接口503,用于与其他设备或通信网络通信,如以太网,无线接入网(RAN),无线局域网(Wireless Local Area Networks,WLAN)等。
存储器502可以是只读存储器(read-only memory,ROM)或可存储静态信息和指令的其他类型的静态存储设备,随机存取存储器(random access memory,RAM)或者可存储信息和指令的其他类型的动态存储设备,也可以是电可擦可编程只读存储器(Electrically Erasable Programmable Read-Only Memory,EEPROM)、只读光盘(Compact Disc Read-Only Memory,CD-ROM)或其他光盘存储、光碟存储(包括压缩光碟、激光碟、光碟、数字通用光碟、蓝光光碟等)、磁盘存储介质或者其他磁存储设备、或者能够用于携带或存储具有指令或数据结构形式的期望的程序代码并能够由计算机存取的任何其他介质,但不限于此。存储器可以是独立存在,通过总线与处理器相连接。存储器也可以和处理器集成在一起。
其中,所述存储器502用于存储执行以上方案的应用程序代码,并由处理器501来控制执行。所述处理器501用于执行所述存储器502中存储的应用程序代码。
存储器502存储的代码可执行以上提供的终端设备执行的上述数据备份方法,比如在将目标数据序列备份至云服务器的过程中,若在备份所述目标数据序列中的数据i的过程中发生中断,则将所述数据i的备份起始点记录为中断节点,所述目标数据序列由多个数据组成;当所述目标数据序列恢复备份时,根据所述中断节点继续将所述目标数据序列备份至所述云服务器。
在一个实施例中,终端设备为手机,下面结合图6对手机的各个构成部件进行具体的介绍:
RF电路610可用于收发信息或通话过程中,信号的接收和发送,特别地,将基站的下行信息接收后,给处理器680处理;另外,将设计上行的数据发送给基站。通常,RF电路610包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器(Low Noise Amplifier,LNA)、双工器等。此外,RF电路610还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于全球移动通讯系统(Global System of Mobile communication,GSM)、通用分组无线服务(General Packet Radio Service,GPRS)、码分多址(Code Division Multiple Access,CDMA)、宽带码分多址(Wideband Code Division Multiple Access,WCDMA)、长期演进(Long Term Evolution,LTE)、电子邮件、短消息服务(Short Messaging Service,SMS)等。
存储器620可用于存储软件程序以及模块,处理器680通过运行存储在存储器620的软件程序以及模块,从而执行手机的各种功能应用以及数据处理。存储器620可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如中断节点记录功能、数据备份功能、数据拆分功能)等;存储数据区可存储根据手机的使用所创建的数据(比如记录的中断点、数据拆分后的N个子数据集)等。此外,存储器620可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
输入单元630可用于接收输入的数字或字符信息,以及产生与手机的用户设置以及功能控制有关的键信号输入。具体地,输入单元630可包括触控面板631、其他输入设备632。触控面板631,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板631上或在触控面板631附近的操作),并根据预先设定的程式驱动相应的连接装置。可选的,触控面板631可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器680,并能接收处理器680发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板631。除以了触控面板631,输入单元630还可以包括其他输入设备632。具体地,其他输入设备632可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的至少一种。
显示单元640可用于显示由用户输入的信息或提供给用户的信息以及手机的各种菜单。显示单元640可包括显示面板641,可选的,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板641。进一步的,触控面板631可覆盖显示面板641,当触控面板631检测到在其上或附近的触摸操作后,传送给处理器580以确定触摸事件的类型,随后处理器680根据触摸事件的类型在显示面板641上提供相应的视觉输出。虽然在图6中,触控面板631与显示面板641是作为两个独立的部件来实现手机的输入和输入功能,但是在某些实施例中,可以将触控面板631与显示面板641集成而实现手机的输入和输出功能。
手机还可包括至少一种传感器650,比如光传感器、运动传感器以及其他传感器。具体地,光传感器可包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板641的亮度,接近传感器可在手机移动到耳边时,关闭显示面板641和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
音频电路660、扬声器661,传声器662可提供用户与手机之间的音频接口。音频电路660可将接收到的音频数据转换后的电信号,传输到扬声器661,由扬声器661转换为声音信号输出;另一方面,传声器662将收集的声音信号转换为电信号,由音频电路660接收后转换为音频数据,再将音频数据输出处理器680处理后,经RF电路610以发送给比如另一手机,或者将音频数据输出至存储器620以便进一步处理。
WiFi属于短距离无线传输技术,手机通过WiFi模块670可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图6示出了WiFi模块670,但是可以理解的是,其并不属于手机的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
处理器680是手机的控制中心,利用各种接口和线路连接整个手机的各个部分,通过运行或执行存储在存储器620内的软件程序和/或模块,以及调用存储在存储器620内的数据,执行手机的各种功能和处理数据,从而对手机进行整体监控。可选的,处理器680可包括一个或多个处理单元;优选的,处理器680可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器680中。
手机还包括给各个部件供电的电源690(比如电池),优选的,电源可以通过电源管理系统与处理器680逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管未示出,手机还可以包括摄像头、蓝牙模块等,在此不再赘述。
前述实施例中,各步骤方法流程可以基于图6所示的终端设备的结构实现。
本发明实施例还提供一种计算机存储介质,其中,该计算机存储介质可存储有程序,该程序执行时包括上述方法实施例中记载的任何一种数据备份方法的部分或全部步骤。
需要说明的是,对于前述的各方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明并不受所描述的动作顺序的限制,因为依据本发明,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作和模块并不一定是本发明所必须的。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其他实施例的相关描述。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置,可通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储器中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储器中,包括若干指令用以使得一台计算机设备(可为个人计算机、服务器或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储器包括:U盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、移动硬盘、磁碟或者光盘等各种可以存储程序代码的介质。
本领域普通技术人员可以理解上述实施例的各种方法中的全部或部分步骤是可以通过程序来指令相关的硬件来完成,该程序可以存储于一计算机可读存储器中,存储器可以包括:闪存盘、只读存储器(英文:Read-Only Memory,简称:ROM)、随机存取器(英文:Random Access Memory,简称:RAM)、磁盘或光盘等。
以上对本发明实施例进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上上述,本说明书内容不应理解为对本发明的限制。