CN104573117A - 基于共享存储实现数据库服务器高可用的方法及*** - Google Patents
基于共享存储实现数据库服务器高可用的方法及*** Download PDFInfo
- Publication number
- CN104573117A CN104573117A CN201510061218.2A CN201510061218A CN104573117A CN 104573117 A CN104573117 A CN 104573117A CN 201510061218 A CN201510061218 A CN 201510061218A CN 104573117 A CN104573117 A CN 104573117A
- Authority
- CN
- China
- Prior art keywords
- database server
- node
- data base
- local data
- base example
- 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.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/21—Design, administration or maintenance of databases
- G06F16/217—Database tuning
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/21—Design, administration or maintenance of databases
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明涉及一种基于共享存储实现数据库服务器高可用的方法,其中包括:数据库服务器检测其自身的网络服务质量和地数据库实例状态;数据库服务器根据自身的网络质量、自身的地数据库实例状态和其它数据库服务器的地数据库实例状态判断是否开启自身节点的地数据库实例;此外,发明还涉及一种基于共享存储实现数据库服务器高可用的***,该***的各个数据库服务器包括服务检测模块和实例管理模块。采用发明的基于共享存储实现数据库服务器高可用的方法及***,以实例节点状态自测、节点监督其他节点实例状态以及自我管理进程的方式实现高可用性,没有主备节点之分,也不借助第三方节点,结构简单,易于实现,具有更广泛的应用范围。
Description
技术领域
本发明涉及数据库管理领域,尤其涉及共享存储的数据库管理领域,具体是指一种基于共享存储实现数据库服务器高可用的方法及***。
背景技术
随着大数据和云计算时代的到来,数据库的应用从大型企业不断地延伸到中小企业。传统的针对大型企业的高可用集群软件不仅技术复杂价格昂贵,而且后期维护费用也很高。中小企业的经济和技术实力相对比较薄弱,急需要一种廉价的解决方案来解决项目中的数据库可用性问题。这里的高可用性(High ailability)指的是通过尽量缩短因日常维护操作(计划)和突发的***崩溃(非计划)所导致的停机时间,以提高***和应用的可用性。它与被认为是不间断操作的容错技术有所不同。高可用性***是目前企业防止核心计算机***因故障停机的最有效手段。例如,当其中某一台服务器出现故障时,可将访问请求转移到其它可以正常工作的服务器上,这就保证了公司和企业的核心业务***安全、高效的运行。
目前,行业内的高可用性软件主要有IBM(国际商业机器公司)公司的hacmp(高可用性集群多重处理应用程序),HP(惠普)公司的service guard(集群服务软件),Veritas公司的vcs(高可用性群集软件)等,从技术上来说,它们监控的层面都是主机,针对数据库服务的状态侦测很少。以hacmp为例,要判断其oracle是否可用,仅仅是查看一下oracle的进程是否存在,然而,这样的判断方式是不准确的,当oracle数据库处于夯住(hang)状态时,hacmp是无法侦测到的。
发明内容
本发明的目的是克服了上述现有技术的缺点,提供了一种通过数据库服务器节点自行检测网络可用性和数据库实例状态,再与对方节点中的数据库实例状态进行比较,最终判断是否开启或者关闭本节点上的数据库实例,数个数据库服务器之间没有主备之分,易于实施和维护的基于共享存储实现数据库服务器高可用的方法及***。
为了实现上述目的,本发明的基于共享存储实现数据库服务器高可用的方法及***具有如下构成:
该基于共享存储实现数据库服务器高可用的方法,其主要特点是,所述的方法包括以下步骤:
(1)数据库服务器检测其自身节点的网络服务质量和本地数据库实例状态;
(2)所述的数据库服务器根据自身节点的网络质量、自身节点的本地数据库实例状态和其它数据库服务器节点的本地数据库实例状态判断是否开启自身节点的本地数据库实例。
进一步地,所述的数据库服务器根据自身节点的网络质量、自身节点的本地数据库实例状态和其它数据库服务器节点的本地数据库实例状态判断是否开启自身节点的本地数据库实例,包括以下步骤:
(2.1)所述的数据库服务器判断自身节点的网络质量是否良好,如果是,则继续步骤(2.2),否则继续步骤(2.5);
(2.2)所述的数据库服务器判断其它数据库节点的本地数据库实例状态是否均为未开启状态,如果是,则继续步骤(2.3),否则继续步骤(2.5);
(2.3)所述的数据库服务器根据自身节点的本地数据库实例状态判断自身节点的本地数据库实例是否已开启,如果是,则返回上述步骤(1),否则继续步骤(2.4);
(2.4)所述的数据库服务器开启自身节点的本地数据库实例,并返回上述步骤(1);
(2.5)所述的数据库服务器关闭自身节点的本地数据库实例。
进一步地,所述的数据库服务器检测其自身节点的网络服务质量和本地数据库实例状态,具体为:
所述的数据库服务器检测其自身节点与网关之间的心跳网络的通信质量、其自身节点与其它数据库服务器节点之间的心跳网络的通信质量、自身节点的进程状态和自身节点的实例启动状态。
此外,本发明还提供一种基于共享存储实现数据库服务器高可用的***,所述的***包括数个数据库服务器,其主要特点是,各个数据库服务器包括:
服务检测模块,用以检测所述的数据库服务器的网络服务质量和本地数据库实例状态;
实例管理模块,用以根据所述的数据库服务器的网络质量、所述的数据库服务器的本地数据库实例状态和其它数据库服务器节点的本地数据库实例状态判断是否开启该数据库服务器的本地数据库实例。
进一步地,所述的服务检测模块包括网络质量检测单元和本地数据库实例状态检测单元,所述的实例管理模块包括实例状态判断单元和本地数据库实例启停单元。
采用了本发明的基于共享存储实现数据库服务器高可用的方法及***,通过数据库服务器节点自行检测网络可用性和数据库实例状态,再与对方节点中的数据库实例状态进行比较,最终判断是否开启或者关闭本节点上的数据库实例,从而解决数据库软件平台和服务中断导致业务长时间停顿的问题,提供实时全面的高可用服务,故障切换时间短,前端的应用程序不必同步进行修改,仅通过脚本即可实现上述技术方案,提供一种快速、可靠、易于实施和维护、故障快速恢复的数据库服务高可性综合解决方案,其主要具有以下积极效益:
1)本发明以实例节点状态自测、节点监督其他节点实例状态以及自我管理进程的方式实现高可用性,明显区别于其他高可用的集中式管理方式;
2)本发明中的数据库服务器没有主备节点之分,也不借助第三方节点,这种方式大大降低集中式管理节点本身的故障无法实现主备切换或者错乱切换,造成数据库服务抖动甚至中断的可能性。
附图说明
图1为本发明的基于共享存储实现数据库服务器高可用的方法的流程图。
图2为本发明的基于共享存储实现数据库服务器高可用的***的结构框图。
图3为本发明的基于共享存储实现数据库服务器高可用的方法的判定规则流程图。
图4为本发明的一个具体实施例的物理架构图。
具体实施方式
为了能够更清楚地描述本发明的技术内容,下面结合具体实施例来进行进一步的描述。
在一种实施方式中,本发明的基于共享存储实现数据库服务器高可用的方法及***用于实现控制多台数据库服务器完成数据库实例的启动和关闭,如图1和2所示,该***包括服务检测模块(包括网络质量检测单元和本地数据库实例状态检测单元)和实例管理模块(包括实例状态判断单元和本地数据库实例启停单元),该所述方法包括如下步骤:
S1、数据库服务器中的服务检测模块启动,检测该数据库服务器的网络服务质量(包括该数据库服务器与网关之间、该数据库服务器与其它数据库服务器之间的心跳网络的通信质量)和检测本地数据库实例状态(包括自身的进程状态和实例启动状态等);
S2、该数据库服务器启动数据库实例管理模块,根据网络质量、其它数据库服务器节点和该数据库服务节点之间的实例状态综合判断是否启停该数据库服务器的本地数据库实例。
其中,启停本地数据库实例的判断规则如图3所示,当网络质量良好且其它所有节点数据库服务均未开启时,启动本地数据库服务,否则关闭本地数据库服务。
在实际应用中,判断一个数据库服务器是否能够提供服务的标准是:
1、数据库实例的主机的网络服务是否通畅;
2、数据库实例服务是否正常。
在一个实施例中,可以通过shell脚本实现服务检测模块(以下简称S1)和实例管理模块(以下简称S2)的功能,如脚本名称S1.sh、S2.sh。在每个节点上运行S1、S2脚本。按照上述标准实现的检测流程如图3所示,首先采集网络节点中该数据库节点的网络通信状态,如果网络状态正常,再检测该数据库节点的本地数据库实例服务状态,以及将该数据库节点的本地数据库实例服务状态与其他数据库实例服务状态进行比较,如果其它的节点中没有一个节点服务是开启的,则通知S2启动本节点上本地实例服务,否则不做任何操作;如果网络状态不正常,则通知S2中的本地数据库实例启停单元关闭本地实例服务。
更具体地,以oracle数据库为例,根据图4中的物理架构部署oracle数据库,包括以下步骤:
1.将一台共享存储中的存储单元挂接到两台数据库服务器对应目录上;
2.将oracle软件安装在/oracle目录中,数据库文件安装在/oradata目录中;
3.启动S1.sh、S2.sh
由上述方案可知,本实施例的数据库装置相对于现有技术的集群***具有结构简单、配置灵活等特点,通过各个模块之间的巧妙结合能够很容易地实现数据库服务器的高可用性。
采用了本发明的基于共享存储实现数据库服务器高可用的方法及***,通过数据库服务器节点自行检测网络可用性和数据库实例状态,再与对方节点中的数据库实例状态进行比较,最终判断是否开启或者关闭本节点上的数据库实例,从而解决数据库软件平台和服务中断导致业务长时间停顿的问题,提供实时全面的高可用服务,故障切换时间短,前端的应用程序不必同步进行修改,仅通过脚本即可实现上述技术方案,提供一种快速、可靠、易于实施和维护、故障快速恢复的数据库服务高可性综合解决方案,其主要具有以下积极效益:
1)本发明以实例节点状态自测、节点监督其他节点实例状态以及自我管理进程的方式实现高可用性,明显区别于其他高可用的集中式管理方式;
2)本发明中的数据库服务器没有主备节点之分,也不借助第三方节点,这种方式大大降低集中式管理节点本身的故障无法实现主备切换或者错乱切换,造成数据库服务抖动甚至中断的可能性。
在此说明书中,本发明已参照其特定的实施例作了描述。但是,很显然仍可以作出各种修改和变换而不背离本发明的精神和范围。因此,说明书和附图应被认为是说明性的而非限制性的。5 -->
Claims (6)
1.一种基于共享存储实现数据库服务器高可用的方法,其特征在于,所述的方法包括以下步骤:
(1)数据库服务器检测其自身节点的网络服务质量和本地数据库实例状态;
(2)所述的数据库服务器根据自身节点的网络质量、自身节点的本地数据库实例状态和其它数据库服务器节点的本地数据库实例状态判断是否开启自身节点的本地数据库实例。
2.根据权利要求1所述的基于共享存储实现数据库服务器高可用的方法,其特征在于,所述的数据库服务器根据自身节点的网络质量、自身节点的本地数据库实例状态和其它数据库服务器节点的本地数据库实例状态判断是否开启自身节点的本地数据库实例,包括以下步骤:
(2.1)所述的数据库服务器判断自身节点的网络质量是否良好,如果是,则继续步骤(2.2),否则继续步骤(2.5);
(2.2)所述的数据库服务器判断其它数据库节点的本地数据库实例状态是否均为未开启状态,如果是,则继续步骤(2.3),否则继续步骤(2.5);
(2.3)所述的数据库服务器根据自身节点的本地数据库实例状态判断自身节点的本地数据库实例是否已开启,如果是,则返回上述步骤(1),否则继续步骤(2.4);
(2.4)所述的数据库服务器开启自身节点的本地数据库实例,并返回上述步骤(1);
(2.5)所述的数据库服务器关闭自身节点的本地数据库实例。
3.根据权利要求1或2所述的基于共享存储实现数据库服务器高可用的方法,其特征在于,所述的数据库服务器检测其自身节点的网络服务质量和本地数据库实例状态,具体为:
所述的数据库服务器检测其自身节点与网关之间的心跳网络的通信质量、其自身节点与其它数据库服务器节点之间的心跳网络的通信质量、自身节点的进程状态和自身节点的实例启动状态。
4.一种利用权利要求1所述的基于共享存储实现数据库服务器高可用的方法实现基于共享存储的数据库服务器高可用的***,所述的***包括数个数据库服务器,其特征在于,各个数据库服务器包括:
服务检测模块,用以检测所述的数据库服务器的网络服务质量和本地数据库实例状态;
实例管理模块,用以根据所述的数据库服务器的网络质量、所述的数据库服务器的本地数据库实例状态和其它数据库服务器节点的本地数据库实例状态判断是否开启该数据库服务器的本地数据库实例。
5.根据权利要求4所述的实现基于共享存储的数据库服务器高可用的***,其特征在于,所述的服务检测模块包括网络质量检测单元和本地数据库实例状态检测单元。
6.根据权利要求4或5所述的实现基于共享存储的数据库服务器高可用的***,其特征在于,所述的实例管理模块包括实例状态判断单元和本地数据库实例启停单元。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201510061218.2A CN104573117B (zh) | 2015-02-05 | 基于共享存储实现数据库服务器高可用的方法及*** |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201510061218.2A CN104573117B (zh) | 2015-02-05 | 基于共享存储实现数据库服务器高可用的方法及*** |
Publications (2)
Publication Number | Publication Date |
---|---|
CN104573117A true CN104573117A (zh) | 2015-04-29 |
CN104573117B CN104573117B (zh) | 2019-07-16 |
Family
ID=
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107634868A (zh) * | 2017-10-29 | 2018-01-26 | 网宿科技股份有限公司 | 一种管理网络服务的方法和*** |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102722579A (zh) * | 2012-06-07 | 2012-10-10 | 浪潮电子信息产业股份有限公司 | 一种在集群存储***内部数据库的双向同步方法 |
CN102868736A (zh) * | 2012-08-30 | 2013-01-09 | 浪潮(北京)电子信息产业有限公司 | 一种云计算监控框架设计及实现方法及云计算处理设备 |
CN102882909A (zh) * | 2011-07-15 | 2013-01-16 | 易云捷讯科技(北京)有限公司 | 云计算服务监控***及方法 |
CN103647668A (zh) * | 2013-12-16 | 2014-03-19 | 上海证券交易所 | 一种高可用集群内主机群体决策***及切换方法 |
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102882909A (zh) * | 2011-07-15 | 2013-01-16 | 易云捷讯科技(北京)有限公司 | 云计算服务监控***及方法 |
CN102722579A (zh) * | 2012-06-07 | 2012-10-10 | 浪潮电子信息产业股份有限公司 | 一种在集群存储***内部数据库的双向同步方法 |
CN102868736A (zh) * | 2012-08-30 | 2013-01-09 | 浪潮(北京)电子信息产业有限公司 | 一种云计算监控框架设计及实现方法及云计算处理设备 |
CN103647668A (zh) * | 2013-12-16 | 2014-03-19 | 上海证券交易所 | 一种高可用集群内主机群体决策***及切换方法 |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107634868A (zh) * | 2017-10-29 | 2018-01-26 | 网宿科技股份有限公司 | 一种管理网络服务的方法和*** |
WO2019080386A1 (zh) * | 2017-10-29 | 2019-05-02 | 网宿科技股份有限公司 | 一种管理网络服务的方法和*** |
CN107634868B (zh) * | 2017-10-29 | 2020-06-23 | 网宿科技股份有限公司 | 一种管理网络服务的方法和*** |
US10992770B2 (en) | 2017-10-29 | 2021-04-27 | Wangsu Science & Technology Co., Ltd. | Method and system for managing network service |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9141491B2 (en) | Highly available server system based on cloud computing | |
CN104408071A (zh) | 一种基于集群管理器的分布式数据库高可用方法及*** | |
EP3142011B9 (en) | Anomaly recovery method for virtual machine in distributed environment | |
CN108173959B (zh) | 一种集群存储*** | |
CN106856489A (zh) | 一种分布式存储***的服务节点切换方法和装置 | |
CN103729280A (zh) | 一种虚拟机高可用机制 | |
CN111385107B (zh) | 一种服务器的主备切换处理方法及装置 | |
CN112181660A (zh) | 一种基于服务器集群的高可用方法 | |
CN105554074A (zh) | 一种基于rpc通信的nas资源监控***及监控方法 | |
CN103795553A (zh) | 基于监控的主、备服务器切换 | |
CN104317803A (zh) | 数据库集群的数据存取结构和方法 | |
EP2723017A1 (en) | Method, apparatus and system for implementing distributed auto-incrementing counting | |
CN109600264A (zh) | CloudStack云平台 | |
CN108469996A (zh) | 一种基于自动快照的***高可用方法 | |
CN105183591A (zh) | 一种高可用集群的实现方法及*** | |
CN105490847B (zh) | 一种私有云存储***中节点故障实时检测及处理方法 | |
CN110674192A (zh) | 一种Redis高可用VIP漂移方法、终端及存储介质 | |
CN105100185A (zh) | 事务中间件机器环境中处理数据库状态通知的***和方法 | |
CN111314443A (zh) | 基于分布式存储***的节点处理方法、装置和设备及介质 | |
CN117370316A (zh) | 数据库的高可用管理方法和装置、电子设备及存储介质 | |
CN108600156A (zh) | 一种服务器及安全认证方法 | |
CN108154343B (zh) | 一种企业级信息***的应急处理方法及*** | |
CN111698301A (zh) | 一种保证服务延续的服务管理方法、装置及存储介质 | |
CN113254245A (zh) | 一种存储集群的故障检测方法和*** | |
CN104573117A (zh) | 基于共享存储实现数据库服务器高可用的方法及*** |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |