一种数据库的升级方法及升级装置与流程

文档序号:14175069阅读:162来源:国知局
一种数据库的升级方法及升级装置与流程

本发明涉及数据库领域,尤其涉及一种数据库的升级方法及升级装置。



背景技术:

数据库(database)是按照数据结构来组织、存储和管理数据的仓库。

随着数据库的更新越来越频繁,升级数据库的工作变得越来越繁重,相关技术中,数据库的升级工作全部依赖于数据库管理员的手动操作,因此十分耗费人力成本,同时也造成升级效率低下。



技术实现要素:

为了解决上述技术问题,本发明提供一种数据库的升级方法,能够节省人力成本,提高升级效率。

为了达到本发明目的,本发明提供了一种数据库的升级方法,包括:

获取升级安装包中的家目录,将获得的家目录作为目标家目录;其中,所述升级安装包用于升级目标数据库;

删除所述目标数据库的原始家目录;

根据所述原始家目录的备份和所述目标家目录生成升级后的目标数据库。

所述删除目标数据库的原始家目录之前,还包括:

获取所述目标数据库所在服务器的环境变量配置信息;

根据获得的环境变量配置信息获取所述原始家目录的路径信息;

根据所述原始家目录的路径信息找到所述原始家目录;

备份所述原始家目录,得到所述原始家目录的备份。

所述对原始家目录进行备份,得到原始家目录的备份,包括:

获取所述原始家目录占用的存储空间,将获得的存储空间作为第一存储空间;

获取所述服务器的剩余存储空间,将获得的存储空间作为第二存储空间;

判断所述第一存储空间是否大于所述第二存储空间;

如果所述第一存储空间不小于所述第二存储空间,备份所述原始家目录,得到所述原始家目录的备份。

所述备份原始家目录,得到原始家目录的备份之后,还包括:

将获得的原始家目录的备份存储在与所述原始家目录所在的第一路径不同的第二路径下;

所述根据获得的升级安装包获取对应的家目录,将获得的家目录作为目标家目录之后,还包括:

将获得的目标家目录存储在所述第一路径下;

所述根据预先备份的原始家目录和目标家目录生成升级后的目标数据库,包括:

获取所述原始家目录的备份中的配置文件;

将获得的配置文件拷贝到所述第一路径下;

根据所述第一路径下的配置文件和所述目标家目录生成所述升级后的目标数据库。

所述根据第一路径下的配置文件和目标家目录生成升级后的目标数据库之后,还包括:

判断所述升级后的目标数据库是否成功生成;

如果所述升级后的目标数据库没有成功生成,将原始家目录的备份拷贝至第一路径下;

根据所述第一路径下的原始目录的备份生成所述目标数据库。

本发明还提供了一种数据库的升级装置,包括:

获取模块,用于获取升级安装包中的家目录,将获得的家目录作为目标家目录;其中,所述升级安装包用于升级目标数据库;

删除模块,用于删除所述目标数据库的原始家目录;

第一处理模块,用于根据原始家目录的备份和所述目标家目录生成升级后的目标数据库。

还包括:

追踪模块,用于根据原始家目录的路径信息找到所述原始家目录;

备份模块,用于备份所述原始家目录,得到所述原始家目录的备份;

所述获取模块,还用于获取所述目标数据库所在服务器的环境变量配置信息;根据获得的环境变量配置信息获取所述原始家目录的路径信息。

所述备份模块具体用于:

获取所述原始家目录占用的存储空间,将获得的存储空间作为第一存储空间;

获取所述服务器的剩余存储空间,将获得的存储空间作为第二存储空间;

判断所述第一存储空间是否大于所述第二存储空间;

如果所述第一存储空间大于所述第二存储空间,备份所述原始家目录,得到所述原始家目录的备份。

还包括:

存储模块,用于将获得的原始家目录的备份存储在与所述原始家目录所在的第一路径不同的第二路径下;将获得的目标家目录存储在所述第一路径下;

所述第一处理模块具体用于:

获取所述原始家目录的备份中的配置文件;

将获得的配置文件拷贝到所述第一路径下;

根据所述第一路径下的配置文件和所述目标家目录生成所述升级后的目标数据库。

还包括:

判断模块,用于判断所述升级后的目标数据库是否成功生成;

拷贝模块,用于如果所述升级后的目标数据库没有成功生成,将原始家目录的备份拷贝至第一路径下;

第二处理模块,用于根据所述所述第一路径下原始目录的备份生成所述目标数据库。

与现有技术相比,本发明至少包括获取升级安装包中的家目录,将获得的家目录作为目标家目录;删除目标数据库的原始家目录;根据原始家目录的备份和目标家目录生成升级后的目标数据库。从本发明提供的技术方案可见,由于获取了升级安装包中的目标家目录,根据原始家目录的备份和目标家目录生成了升级后的目标数据库,从而实现了数据库的自动升级,极大程度地节省了人力成本,提高了升级效率。

本发明的其它特征和优点将在随后的说明书中阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明而了解。本发明的目的和其他优点可通过在说明书、权利要求书以及附图中所特别指出的结构来实现和获得。

附图说明

附图用来提供对本发明技术方案的进一步理解,并且构成说明书的一部分,与本申请的实施例一起用于解释本发明的技术方案,并不构成对本发明技术方案的限制。

图1为本发明实施例提供的一种数据库的升级方法的流程示意图;

图2为本发明实施例提供的另一种数据库的升级方法的流程示意图;

图3为本发明实施例提供的又一种数据库的升级方法的流程示意图;

图4为本发明实施例提供的一种数据库的升级装置的结构示意图;

图5为本发明实施例提供的另一种数据库的升级装置的结构示意图;

图6为本发明实施例提供的又一种数据库的升级装置的结构示意图。

具体实施方式

为使本发明的目的、技术方案和优点更加清楚明白,下文中将结合附图对本发明的实施例进行详细说明。需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互任意组合。

本发明实施例提供一种数据库的升级方法,如图1所示,该方法包括:

步骤101、获取升级安装包中的家目录,将获得的家目录作为目标家目录。

其中,升级安装包用于升级目标数据库。

需要说明的是,用于升级目标数据库的升级安装包是预先获得的,它可以是通过数据库管理员上传至服务器中。

具体的,升级安装包是一个压缩文件,其中包含新的家目录,也就是升级后的目标数据库的家目录(此时升级后的目标数据库还未生成,而需要根据它的家目录去生成),因此只要对升级安装包进行解压,就能得到升级后的目标数据库的家目录。

步骤102、删除目标数据库的原始家目录。

具体的,由于原始家目录是目标数据库的家目录,因此当获得了升级后的目标数据库的家目录后,需要将原始家目录进行删除

步骤103、根据原始家目录的备份和目标家目录生成升级后的目标数据库。

具体的,原始家目录的备份是预先获得的,目标数据库的可执行文件、库文件等等信息全部存在于原始家目录中,原始家目录中有目标数据库的配置文件,目标家目录有升级文件,但缺少这些配置文件,而生成升级后的目标数据库需要这些配置文件,因此根据预先获得的原始家目录的备份和目标家目录就能够生成升级后的目标数据库。

本发明实施例所提供的数据库的升级方法,获取升级安装包中的家目录,将获得的家目录作为目标家目录;删除目标数据库的原始家目录;根据原始家目录的备份和目标家目录生成升级后的目标数据库。从本发明提供的技术方案可见,由于获取了升级安装包中的目标家目录,根据原始家目录的备份和目标家目录生成了升级后的目标数据库,从而实现了数据库的自动升级,极大程度地节省了人力成本,提高了升级效率。

本发明实施例提供另一种数据库的升级方法,如图2所示,该方法包括:

步骤201、获取目标数据库所在服务器的环境变量配置信息。

步骤202、根据获得的环境变量配置信息获取原始家目录的路径信息。

步骤203、根据原始家目录的路径信息找到原始家目录。

步骤204、备份原始家目录,得到原始家目录的备份。

具体的,步骤204可以通过步骤204a~204d实现:

步骤204a、获取原始家目录占用的存储空间,将获得的存储空间作为第一存储空间。

步骤204b、获取服务器的剩余存储空间,将获得的存储空间作为第二存储空间。

步骤204c、判断第一存储空间是否大于第二存储空间。

步骤204d、如果第一存储空间不小于第二存储空间,备份原始家目录,得到原始家目录的备份。

具体的,如果第一存储空间小于第二存储空间,则无法进行原始家目录的备份,程序报错。

步骤205、获取升级安装包中的家目录,将获得的家目录作为目标家目录。

其中,升级安装包用于升级目标数据库。

步骤206、删除目标数据库的原始家目录。

步骤207、根据原始家目录的备份和目标家目录生成升级后的目标数据库。

本发明实施例所提供的数据库的升级方法,获取升级安装包中的家目录,将获得的家目录作为目标家目录;删除目标数据库的原始家目录;根据原始家目录的备份和目标家目录生成升级后的目标数据库。从本发明提供的技术方案可见,由于获取了升级安装包中的目标家目录,根据原始家目录的备份和目标家目录生成了升级后的目标数据库,从而实现了数据库的自动升级,极大程度地节省了人力成本,提高了升级效率。

本发明实施例提供又一种数据库的升级方法,如图3所示,该方法包括:

步骤301、获取目标数据库所在服务器的环境变量配置信息。

步骤302、根据获得的环境变量配置信息获取原始家目录的路径信息。

步骤303、根据原始家目录的路径信息找到原始家目录。

步骤304、备份原始家目录,得到原始家目录的备份。

步骤305、将获得的原始家目录的备份存储在与原始家目录所在的第一路径不同的第二路径下。

需要说明的是,原始家目录所在的第一路径是家目录通常所存在的路径

步骤306、获取升级安装包中的家目录,将获得的家目录作为目标家目录。

其中,升级安装包用于升级目标数据库。

步骤307、将获得的目标家目录存储在第一路径下。

步骤308、删除目标数据库的原始家目录。

步骤309、获取原始家目录的备份中的配置文件。

具体的,配置文件包括参数文件、监听文件、数据文件和授权license文件等。

全部拷贝回新解压的数据库录。其中

步骤310、将获得的配置文件拷贝到第一路径下。

具体的,数据文件回拷时,需要注意数据文件可能存放在原始家目录的备份下的数据库目录中,也可能存放在单独的磁盘分区上,如果数据文件存放在原始家目录的备份下的数据库目录,当原始家目录的备份的名称与原始家目录的名称不相同时,数据文件将无法被读取,因此直接将原始家目录的备份下的数据库目录拷贝到目标家目录中(即第一路径下),就可以避免数据文件可能无法被读取的问题。

步骤311、根据第一路径下的配置文件和目标家目录生成升级后的目标数据库。

具体的,由于配置文件和目标家目录中包含有升级后的目标数据库所有需要的文件,因此当获得了配置文件和目标家目录,再运行目标家目录中的可执行文件就可以生成升级后的目标数据库。

步骤312、判断升级后的目标数据库是否成功生成。

具体的,由于实际在根据拷贝到第一路径下的配置文件和目标家目录生成升级后的目标数据库的过程中,可能会出现某些特殊情况,从而造成升级不成功,因此需要进一步判断升级后的目标数据库是否成功生成。

具体的,如果升级后的目标数据库成功生成,在数据库启动正常后,可以执行升级后的目标数据库的system.sh脚本,重新生成数据库字典,从而能够正常使用升级后的目标数据库的数据库特性。

步骤313、如果升级后的目标数据库没有成功生成,将原始家目录的备份拷贝至第一路径下。

步骤314、根据第一路径下的原始目录的备份生成目标数据库。

需要说明的是,步骤313和314是在升级后的目标数据库没有成功生成的情况下进行的补救措施,如果升级后的目标数据库没有成功生成,那么还可以重新生成原来的数据库,即目标数据库。

本发明实施例所提供的数据库的升级方法,获取升级安装包中的家目录,将获得的家目录作为目标家目录;删除目标数据库的原始家目录;根据原始家目录的备份和目标家目录生成升级后的目标数据库。从本发明提供的技术方案可见,由于获取了升级安装包中的目标家目录,根据原始家目录的备份和目标家目录生成了升级后的目标数据库,从而实现了数据库的自动升级,极大程度地节省了人力成本,提高了升级效率。

本发明实施例还提供一种数据库的升级装置,如图4所示,该数据库的升级装置4包括:

获取模块41,用于获取升级安装包中的家目录,将获得的家目录作为目标家目录;其中,升级安装包用于升级目标数据库。

删除模块42,用于删除目标数据库的原始家目录。

第一处理模块43,用于根据原始家目录的备份和目标家目录生成升级后的目标数据库。

进一步,在图4对应的实施例的基础上,本发明实施例提供另一种数据库的升级装置,如图5所示,该数据库的升级装置4还包括:

追踪模块44,用于根据原始家目录的路径信息找到原始家目录;

备份模块45,用于备份原始家目录,得到原始家目录的备份;

获取模块41,还用于获取目标数据库所在服务器的环境变量配置信息;根据获得的环境变量配置信息获取原始家目录的路径信息。

进一步,备份模块45具体用于:

获取原始家目录占用的存储空间,将获得的存储空间作为第一存储空间;

获取服务器的剩余存储空间,将获得的存储空间作为第二存储空间。

判断第一存储空间是否大于第二存储空间。

如果第一存储空间大于第二存储空间,备份原始家目录,得到原始家目录的备份。

进一步,在图5对应的实施例的基础上,本发明实施例提供又一种数据库的升级装置,如图6所示,该数据库的升级装置4还包括:

存储模块46,用于将获得的原始家目录的备份存储在与原始家目录所在的第一路径不同的第二路径下;将获得的目标家目录存储在第一路径下。

判断模块47,用于判断升级后的目标数据库是否成功生成。

拷贝模块48,用于如果升级后的目标数据库没有成功生成,将原始家目录的备份拷贝至第一路径下。

第二处理模块49,用于根据第一路径下原始目录的备份生成目标数据库。

第一处理模块43具体用于。

获取原始家目录的备份中的配置文件。

将获得的配置文件拷贝到第一路径下。

根据第一路径下的配置文件和目标家目录生成升级后的目标数据库。

本发明实施例所提供的数据库的升级装置,获取升级安装包中的家目录,将获得的家目录作为目标家目录;删除目标数据库的原始家目录;根据原始家目录的备份和目标家目录生成升级后的目标数据库。从本发明提供的技术方案可见,由于获取了升级安装包中的目标家目录,根据原始家目录的备份和目标家目录生成了升级后的目标数据库,从而实现了数据库的自动升级,极大程度地节省了人力成本,提高了升级效率。

在实际应用中,所述获取模块41、删除模块42、第一处理模块43、追踪模块44、备份模块45、存储模块46、判断模块47、拷贝模块48和第二处理模块49均可由位于数据库的升级装置中的中央处理器(centralprocessingunit,cpu)、微处理器(microprocessorunit,mpu)、数字信号处理器(digitalsignalprocessor,dsp)或现场可编程门阵列(fieldprogrammablegatearray,fpga)等实现。

本发明实施例还提供一种用于升级数据库的装置,包括存储器和处理器,其中,存储器中存储有以下可被处理器执行的指令:

获取升级安装包中的家目录,将获得的家目录作为目标家目录;其中,升级安装包用于升级目标数据库。

删除目标数据库的原始家目录。

根据原始家目录的备份和目标家目录生成升级后的目标数据库。

进一步,存储器中具体还存储有以下可被处理器执行的指令:

获取目标数据库所在服务器的环境变量配置信息。

根据获得的环境变量配置信息获取原始家目录的路径信息。

根据原始家目录的路径信息找到原始家目录。

备份原始家目录,得到原始家目录的备份。

进一步,存储器中还具体存储有以下可被处理器执行的指令:

获取原始家目录占用的存储空间,将获得的存储空间作为第一存储空间。

获取服务器的剩余存储空间,将获得的存储空间作为第二存储空间。

判断第一存储空间是否大于第二存储空间。

如果第一存储空间不小于第二存储空间,备份原始家目录,得到原始家目录的备份。

进一步,存储器中具体还存储有以下可被处理器执行的指令:

将获得的原始家目录的备份存储在与原始家目录所在的第一路径不同的第二路径下。

将获得的目标家目录存储在第一路径下。

获取原始家目录的备份中的配置文件。

将获得的配置文件拷贝到第一路径下。

根据第一路径下的配置文件和目标家目录生成升级后的目标数据库。

进一步,存储器中具体还存储有以下可被处理器执行的指令:

判断升级后的目标数据库是否成功生成。

如果升级后的目标数据库没有成功生成,将原始家目录的备份拷贝至第一路径下。

根据第一路径下的原始目录的备份生成目标数据库。

虽然本发明所揭露的实施方式如上,但的内容仅为便于理解本发明而采用的实施方式,并非用以限定本发明。任何本发明所属领域内的技术人员,在不脱离本发明所揭露的精神和范围的前提下,可以在实施的形式及细节上进行任何的修改与变化,但本发明的专利保护范围,仍须以所附的权利要求书所界定的范围为准。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1