一种数据库备份容错方法、系统、终端及存储介质与流程

专利2022-06-29  64


本发明涉及数据存储技术领域,具体涉及一种数据库备份容错方法、系统、终端及存储介质。



背景技术:

dataguard是oracle数据库常使用的一种高可用方案,主库数据向备库进行同步,常用的同步方法是主库的归档日志自动同步到备库,备库应用这些归档日志,实现主库和备库数据的同步。主备库正常完成首次同步配置后,主库新产生的归档日志会自动同步到备库主机,然后备库再应用主库同步过来的归档日志,使备库和主库数据基本能保持准实时一致。主库做的任何操作(不管是对的还是错的)都会通过dataguard功能同步给备库,当主库进行了一些失误操作,比如删除了表数据、删除表等,备库也会进行相应的操作,备库分不清哪些是正确的哪些是不正确的,所以这时无法通过简单方法在备库得到失误操作之前的数据,可能需要使用数据库备份对数据库进行恢复才能找回失误操作之前的数据,这个过程需要花费较长时间,对业务的影响较大。



技术实现要素:

针对现有技术的上述不足,本发明提供一种数据库备份容错方法、系统、终端及存储介质,以解决上述技术问题。

第一方面,本发明提供一种数据库备份容错方法,包括:

设置备份等待时间;

接收并缓存主库的归档日志,记录归档日志的缓存时间;

判断所述缓存时间是否达到所述备份等待时间:

若是,则根据所述归档日志对备库相应数据进行更新。

进一步的,所述记录归档日志的缓存时间包括:

读取所述归档日志的scn号;

在sys.smon_scn_time表中查询所述scn号对应的开始时间;

采集系统当前时间;

计算所述当前时间与开始时间的时间差,并将所述时间差作为缓存时间输出。

进一步的,所述根据归档日志对备库相应数据进行更新,包括:

读取所述归档日志中的更新数据和数据位置;

根据所述数据位置定位备库中的待替换数据;

利用所述更新数据替换掉所述待替换数据。

进一步的,所述方法还包括:

接收来自主库的数据调用命令;

根据所述数据调用命令查找备库中的备份数据和相应归档日志;

提取所述相应归档日志中的更新数据;

分别标记备份数据和更新数据的创建时间;

输出带有创建时间标记的备份数据和更新数据。

第二方面,本发明提供一种数据库备份容错系统,包括:

时间设置单元,配置用于设置备份等待时间;

时间记录单元,配置用于接收并缓存主库的归档日志,记录归档日志的缓存时间;

时间判断单元,配置用于判断所述缓存时间是否达到所述备份等待时间;

更新执行单元,配置用于若所述缓存时间达到所述备份等待时间,则根据所述归档日志对备库相应数据进行更新。

进一步的,所述时间记录单元包括:

信息读取模块,配置用于读取所述归档日志的scn号;

时间换算模块,配置用于在sys.smon_scn_time表中查询所述scn号对应的开始时间;

时间采集模块,配置用于采集系统当前时间;

时间做差模块,配置用于计算所述当前时间与开始时间的时间差,并将所述时间差作为缓存时间输出。

进一步的,所述更新执行单元包括:

日志读取模块,配置用于读取所述归档日志中的更新数据和数据位置;

替换定位模块,配置用于根据所述数据位置定位备库中的待替换数据;

替换执行模块,配置用于利用所述更新数据替换掉所述待替换数据。

进一步的,所述系统还包括:

命令接收单元,配置用于接收来自主库的数据调用命令;

备份查找单元,配置用于根据所述数据调用命令查找备库中的备份数据和相应归档日志;

数据提取单元,配置用于提取所述相应归档日志中的更新数据;

时间标记单元,配置用于分别标记备份数据和更新数据的创建时间;

数据输出单元,配置用于输出带有创建时间标记的备份数据和更新数据。

第三方面,提供一种终端,包括:

处理器、存储器,其中,

该存储器用于存储计算机程序,

该处理器用于从存储器中调用并运行该计算机程序,使得终端执行上述的终端的方法。

第四方面,提供了一种计算机存储介质,所述计算机可读存储介质中存储有指令,当其在计算机上运行时,使得计算机执行上述各方面所述的方法。

本发明的有益效果在于,

本发明提供的数据库备份容错方法、系统、终端及存储介质,通过设置备份等待时间,是备库与主库的数据更新保持一个时间差,记录备库接收自主库的归档日志的缓存时间,当缓存时间达到预先设置的等待时间后,根据该归档日志的内容对备库的相应数据进行更新。本发明能够提高备份数据库的容错性能,在保证数据同步的前提下有效避免由于主库操作失误导致的重要数据无法恢复。

此外,本发明设计原理可靠,结构简单,具有非常广泛的应用前景。

附图说明

为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,对于本领域普通技术人员而言,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。

图1是本发明一个实施例的方法的示意性流程图。

图2是本发明一个实施例的系统的示意性框图。

图3为本发明实施例提供的一种终端的结构示意图。

具体实施方式

为了使本技术领域的人员更好地理解本发明中的技术方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。

下面对本发明中出现的关键术语进行解释。

scn:(systemchangenumber简称scn)是当oracle数据库更新后,由dbms自动维护去累积递增的一个数字。

图1是本发明一个实施例的方法的示意性流程图。其中,图1执行主体可以为一种数据库备份容错系统。

如图1所示,该方法100包括:

步骤110,设置备份等待时间;

步骤120,接收并缓存主库的归档日志,记录归档日志的缓存时间;

步骤130,判断所述缓存时间是否达到所述备份等待时间:

步骤140,若是,则根据所述归档日志对备库相应数据进行更新。

为了便于对本发明的理解,下面以本发明数据库备份容错方法的原理,结合实施例中对数据库备份进行容错设计的过程,对本发明提供的数据库备份容错方法做进一步的描述。

具体的,所述数据库备份容错方法包括:

s1、设置备份等待时间。

根据用户需要设置备份等待时间,该等待时间可以随时灵活根据需要调整生效,比如:当主库误删一张表,而参数“主备库时间差”设置的是120(即2小时),也就是备库在两小时后才会执行到删除表的操作。若为了使表中的数据尽可能的是最新状态并且最短时间内获得表及数据,那就需要加快备库对归档日志的应用,通过缩短备份等待时间,就可以加快备库对归档日志的应用。

s2、接收并缓存主库的归档日志,记录归档日志的缓存时间。

主库有数据更新后会生成归档日志,归档日志发送至备库。主库每次更新生成的归档日志中都有一个scn号,scn号由dbms自动维护去累积递增的一个数字。每个scn号都对应一个时间,两者是一一对应的关系,scn号与时间的对应关系保存在sys.smon_scn_time表中,sys.smon_scn_time表为数据库的一个记录表。

因此接收到主库的归档日志后,缓存归档日志,提取归档日志的scn号,查找sys.smon_scn_time表中与提取的scn号对应的时间,记录为开始时间。采集备库管理端系统当前时间,计算当前时间与开始时间的时间差,将该时间差记为缓存时间。

s3、判断所述缓存时间是否达到所述备份等待时间:若是,则根据所述归档日志对备库相应数据进行更新。

判断步骤s2得到的缓存时间是否达到步骤s1设置的等待时间,若达到则执行以下步骤:

读取归档日志中的更新数据和数据位置,根据数据位置定位备库中的待替换数据,利用更新数据替换掉备库的待替换数据。完成替换后删除归档日志。

若接收到来自主库的数据调用命令,根据数据调用命令查找备库中的备份数据和相应归档日志,其中若相应归档日志的缓存时间未达到等待时间,则可以查找到,若相应归档日志的缓存时间已经达到等待时间且完成数据替换,则该相应归档日志已经被清除,无法查找。

若能够查找到相应归档日志,提取所述相应归档日志中的更新数据,分别标记备份数据和更新数据的创建时间,输出带有创建时间标记的备份数据和更新数据。

若不能够查找相应归档日志,则仅输出查找到的备份数据即可。

如图2示,该系统200包括:

时间设置单元210,配置用于设置备份等待时间;

时间记录单元220,配置用于接收并缓存主库的归档日志,记录归档日志的缓存时间;

时间判断单元230,配置用于判断所述缓存时间是否达到所述备份等待时间;

更新执行单元240,配置用于若所述缓存时间达到所述备份等待时间,则根据所述归档日志对备库相应数据进行更新。

可选地,作为本发明一个实施例,所述时间记录单元包括:

信息读取模块,配置用于读取所述归档日志的scn号;

时间换算模块,配置用于在sys.smon_scn_time表中查询所述scn号对应的开始时间;

时间采集模块,配置用于采集系统当前时间;

时间做差模块,配置用于计算所述当前时间与开始时间的时间差,并将所述时间差作为缓存时间输出。

可选地,作为本发明一个实施例,所述更新执行单元包括:

日志读取模块,配置用于读取所述归档日志中的更新数据和数据位置;

替换定位模块,配置用于根据所述数据位置定位备库中的待替换数据;

替换执行模块,配置用于利用所述更新数据替换掉所述待替换数据。

可选地,作为本发明一个实施例,所述系统还包括:

命令接收单元,配置用于接收来自主库的数据调用命令;

备份查找单元,配置用于根据所述数据调用命令查找备库中的备份数据和相应归档日志;

数据提取单元,配置用于提取所述相应归档日志中的更新数据;

时间标记单元,配置用于分别标记备份数据和更新数据的创建时间;

数据输出单元,配置用于输出带有创建时间标记的备份数据和更新数据。

图3为本发明实施例提供的一种终端系统300的结构示意图,该终端系统300可以用于执行本发明实施例提供的数据库备份容错方法。

其中,该终端系统300可以包括:处理器310、存储器320及通信单元330。这些组件通过一条或多条总线进行通信,本领域技术人员可以理解,图中示出的服务器的结构并不构成对本发明的限定,它既可以是总线形结构,也可以是星型结构,还可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。

其中,该存储器320可以用于存储处理器310的执行指令,存储器320可以由任何类型的易失性或非易失性存储终端或者它们的组合实现,如静态随机存取存储器(sram),电可擦除可编程只读存储器(eeprom),可擦除可编程只读存储器(eprom),可编程只读存储器(prom),只读存储器(rom),磁存储器,快闪存储器,磁盘或光盘。当存储器320中的执行指令由处理器310执行时,使得终端300能够执行以下上述方法实施例中的部分或全部步骤。

处理器310为存储终端的控制中心,利用各种接口和线路连接整个电子终端的各个部分,通过运行或执行存储在存储器320内的软件程序和/或模块,以及调用存储在存储器内的数据,以执行电子终端的各种功能和/或处理数据。所述处理器可以由集成电路(integratedcircuit,简称ic)组成,例如可以由单颗封装的ic所组成,也可以由连接多颗相同功能或不同功能的封装ic而组成。举例来说,处理器310可以仅包括中央处理器(centralprocessingunit,简称cpu)。在本发明实施方式中,cpu可以是单运算核心,也可以包括多运算核心。

通信单元330,用于建立通信信道,从而使所述存储终端可以与其它终端进行通信。接收其他终端发送的用户数据或者向其他终端发送用户数据。

本发明还提供一种计算机存储介质,其中,该计算机存储介质可存储有程序,该程序执行时可包括本发明提供的各实施例中的部分或全部步骤。所述的存储介质可为磁碟、光盘、只读存储记忆体(英文:read-onlymemory,简称:rom)或随机存储记忆体(英文:randomaccessmemory,简称:ram)等。

因此,本发明通过设置备份等待时间,是备库与主库的数据更新保持一个时间差,记录备库接收自主库的归档日志的缓存时间,当缓存时间达到预先设置的等待时间后,根据该归档日志的内容对备库的相应数据进行更新。本发明能够提高备份数据库的容错性能,在保证数据同步的前提下有效避免由于主库操作失误导致的重要数据无法恢复,本实施例所能达到的技术效果可以参见上文中的描述,此处不再赘述。

本领域的技术人员可以清楚地了解到本发明实施例中的技术可借助软件加必需的通用硬件平台的方式来实现。基于这样的理解,本发明实施例中的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中如u盘、移动硬盘、只读存储器(rom,read-onlymemory)、随机存取存储器(ram,randomaccessmemory)、磁碟或者光盘等各种可以存储程序代码的介质,包括若干指令用以使得一台计算机终端(可以是个人计算机,服务器,或者第二终端、网络终端等)执行本发明各个实施例所述方法的全部或部分步骤。

本说明书中各个实施例之间相同相似的部分互相参见即可。尤其,对于终端实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例中的说明即可。

在本发明所提供的几个实施例中,应该理解到,所揭露的系统和方法,可以通过其它的方式实现。例如,以上所描述的系统实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,系统或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。

所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。

另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。

尽管通过参考附图并结合优选实施例的方式对本发明进行了详细描述,但本发明并不限于此。在不脱离本发明的精神和实质的前提下,本领域普通技术人员可以对本发明的实施例进行各种等效的修改或替换,而这些修改或替换都应在本发明的涵盖范围内/任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。


技术特征:

1.一种数据库备份容错方法,其特征在于,包括:

设置备份等待时间;

接收并缓存主库的归档日志,记录归档日志的缓存时间;

判断所述缓存时间是否达到所述备份等待时间:

若是,则根据所述归档日志对备库相应数据进行更新。

2.根据权利要求1所述的方法,其特征在于,所述记录归档日志的缓存时间包括:

读取所述归档日志的scn号;

在sys.smon_scn_time表中查询所述scn号对应的开始时间;

采集系统当前时间;

计算所述当前时间与开始时间的时间差,并将所述时间差作为缓存时间输出。

3.根据权利要求1所述的方法,其特征在于,所述根据归档日志对备库相应数据进行更新,包括:

读取所述归档日志中的更新数据和数据位置;

根据所述数据位置定位备库中的待替换数据;

利用所述更新数据替换掉所述待替换数据。

4.根据权利要求1所述的方法,其特征在于,所述方法还包括:

接收来自主库的数据调用命令;

根据所述数据调用命令查找备库中的备份数据和相应归档日志;

提取所述相应归档日志中的更新数据;

分别标记备份数据和更新数据的创建时间;

输出带有创建时间标记的备份数据和更新数据。

5.一种数据库备份容错系统,其特征在于,包括:

时间设置单元,配置用于设置备份等待时间;

时间记录单元,配置用于接收并缓存主库的归档日志,记录归档日志的缓存时间;

时间判断单元,配置用于判断所述缓存时间是否达到所述备份等待时间;

更新执行单元,配置用于若所述缓存时间达到所述备份等待时间,则根据所述归档日志对备库相应数据进行更新。

6.根据权利要求5所述的系统,其特征在于,所述时间记录单元包括:

信息读取模块,配置用于读取所述归档日志的scn号;

时间换算模块,配置用于在sys.smon_scn_time表中查询所述scn号对应的开始时间;

时间采集模块,配置用于采集系统当前时间;

时间做差模块,配置用于计算所述当前时间与开始时间的时间差,并将所述时间差作为缓存时间输出。

7.根据权利要求5所述的系统,其特征在于,所述更新执行单元包括:

日志读取模块,配置用于读取所述归档日志中的更新数据和数据位置;

替换定位模块,配置用于根据所述数据位置定位备库中的待替换数据;

替换执行模块,配置用于利用所述更新数据替换掉所述待替换数据。

8.根据权利要求5所述的系统,其特征在于,所述系统还包括:

命令接收单元,配置用于接收来自主库的数据调用命令;

备份查找单元,配置用于根据所述数据调用命令查找备库中的备份数据和相应归档日志;

数据提取单元,配置用于提取所述相应归档日志中的更新数据;

时间标记单元,配置用于分别标记备份数据和更新数据的创建时间;

数据输出单元,配置用于输出带有创建时间标记的备份数据和更新数据。

9.一种终端,其特征在于,包括:

处理器;

用于存储处理器的执行指令的存储器;

其中,所述处理器被配置为执行权利要求1-4任一项所述的方法。

10.一种存储有计算机程序的计算机可读存储介质,其特征在于,该程序被处理器执行时实现如权利要求1-4中任一项所述的方法。

技术总结
本发明提供一种数据库备份容错方法、系统、终端及存储介质,包括:设置备份等待时间;接收并缓存主库的归档日志,记录归档日志的缓存时间;判断所述缓存时间是否达到所述备份等待时间:若是,则根据所述归档日志对备库相应数据进行更新。本发明能够提高备份数据库的容错性能,在保证数据同步的前提下有效避免由于主库操作失误导致的重要数据无法恢复。

技术研发人员:马国良
受保护的技术使用者:苏州浪潮智能科技有限公司
技术研发日:2020.01.13
技术公布日:2020.06.09

转载请注明原文地址: https://bbs.8miu.com/read-27340.html

最新回复(0)