[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

CN103425645A - 数据库集群单点故障的监控系统及方法 - Google Patents

数据库集群单点故障的监控系统及方法 Download PDF

Info

Publication number
CN103425645A
CN103425645A CN2012101489389A CN201210148938A CN103425645A CN 103425645 A CN103425645 A CN 103425645A CN 2012101489389 A CN2012101489389 A CN 2012101489389A CN 201210148938 A CN201210148938 A CN 201210148938A CN 103425645 A CN103425645 A CN 103425645A
Authority
CN
China
Prior art keywords
storehouse
data
read
terminal
database
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
Application number
CN2012101489389A
Other languages
English (en)
Other versions
CN103425645B (zh
Inventor
朱金清
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Alibaba Group Holding Ltd
Original Assignee
Alibaba Group Holding Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Alibaba Group Holding Ltd filed Critical Alibaba Group Holding Ltd
Priority to CN201210148938.9A priority Critical patent/CN103425645B/zh
Publication of CN103425645A publication Critical patent/CN103425645A/zh
Application granted granted Critical
Publication of CN103425645B publication Critical patent/CN103425645B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本申请公开了一种数据库集群单点故障的监控系统及方法,应用于若干个数据库的数据库集群中,所述数据库包括主库或从库,监控系统包括:若干个数据库代理,至少三个基于分布式协调机制相互通信的协调终端,其中至少三个协调终端中包括一个领导协调终端;一个数据库代理与数据库集群中的一个数据库对应设置在一台服务器上,每个数据库代理中均保存各个协调终端的地址;通过数据库代理定时检测对应数据库的读写状态,领导协调终端根据来自数据库代理的数据库读写状态信息,对数据库集群中的单点故障进行识别,能够高效、可靠地识别数据库集群中的单点故障,能够解决现有技术中,分布式MySQL数据库单点故障的解决方案中存在的效率低下的问题。

Description

数据库集群单点故障的监控系统及方法
技术领域
本申请涉及网络通信系统,具体地,涉及一种数据库集群单点故障的监控系统及方法。
背景技术
目前,互联网公司通常采用数据库集群来存储网站的海量数据。数据库集群的结构如图1所示,主库(Master)1提供对外的读写服务,若干个从库(Slave)2只对外提供读服务,以MySQL数据库为例,主库1和从库2均为MySQL实例,从而图1所示的数据库集群构成一个MySQL集群,每一个MySQL数据库(包括主库和从库)都是一个单点。各个MySQL数据库之间的关系包括:通过复制机制,从库2根据主库1定期发送的日志,不断地从主库1中读取更新的数据,从而使得从库2尽量与主库1的数据保持一致,使得应用端3(Client)从从库2中读取的数据与主库一致。
在实际运行中,互联网公司使用的服务器大部分都是普通的个人电脑(PC,Personal Computer)服务器(Server),PC Server存在一定的故障率,如通常会发生内存异常、主板异常、或者直接宕机,发生故障的PC Server就无法向外提供服务,这就是MySQL数据库的单点故障,如果正好是主库1的机器出现问题,那么应用端3(Client)对主库1写入数据的操作就会受影响,影响到数据库集群对外提供的写服务。
目前,针对MySQL数据库的单点故障主要有以下两种解决方案:
第一种方案,采用人工干预的解决办法。该方法包括:人工确认主库1是否存活(即正常向外提供读写服务),若存活,则将主库1直接启动,以确定从库2是否能够正常同步,若主库1中的数据损坏或者主库1不存活(即不能正常向外提供读写服务),则选择一台数据较新的从库2作为新主库。具体地,将该新主库设置为可读写的状态,将原主库1的读写状态设置为只读状态,然后通知前端应用或者中间层将数据写入新的主库,从而完成主从数据库的切换。上述过程均需要人工干预。如果主库和从库在同一个网段的话,采用虚拟IP的方式,主备切换不会影响到前端应用或者中间层的切换,影响到数据写入的时间几乎为零;但是,对于主库和从库跨机房部署、不属于同一个网段的情况,主备切换则会影响到前端应用或者中间层的切换,也即对数据的写入造成影响。
第二种方案,设置一个单点监控端,打通该单点监控端与所有MySQL数据库之间的信任关系(例如,打通ssh信任关系),从该单点监控端定时与当前的MySQL主库进行通信,以ssh判断方式来判断识别主库是否存活(即可提供写服务),在判断发生单点故障时,调用程序控制实现新的主库的选举,新库的选举过程与上述第一种方案中的主从数据库的切换处理方式类似,在切换完成后,基于ssh信任关系使新主库中的数据与旧主库中的数据保持同步,该方案通过增设单点监控端作为探测源,用它判断主库的故障,从而替代原来的人工判断。
上述的方案一中存在人工切换处理效率低、切换时间长、容易丢失写入的数据的问题。而上述方案二中单点监控端必须首先打通与其他MySQL数据库之间的ssh信任关系,这一处理过程仍需人工进行处理、处理过程复杂繁琐、效率较低,对于ssh信任关系的维护也同样复杂繁琐;单点监控端需要基于ssh判断方式对单点故障进行识别,处理过程复杂、低效;并且打通了ssh信任关系后,通过单点监控端就能够访问到其他MySQL数据库的数据,这样对数据安全性造成威胁,并且如果单点监控端与MySQL主库同时发生故障,就无法通过单点监控端来实现主从数据库的切换,从而降低了系统的稳定性。
可见,在现有技术中,MySQL数据库集群单点故障的解决方案中存在效率低下、数据安全性差、系统稳定性差的问题。
发明内容
针对现有技术中分布式MySQL数据库单点故障的解决方案中存在的效率低下、数据安全性差、系统稳定性差的问题,本申请实施例提供了一种数据库集群单点故障的监控系统,用以解决至少一个上述问题。
相应地,本申请实施例还提供了一种数据库集群单点故障的监控方法。
本申请实施例技术方案如下:
一种数据库集群单点故障的监控系统,应用于包括若干个数据库的数据库集群中,数据库包括主库或从库,监控系统包括:若干个数据库代理,至少三个基于分布式协调机制相互通信的协调终端,其中至少三个协调终端中包括一个领导协调终端;一个数据库代理与数据库集群中的一个数据库对应设置在一台服务器上,每个数据库代理中均保存各个协调终端的地址;数据库代理,用于定时检测对应数据库的读写状态,并将检测得到的数据库读写状态信息发送给领导协调终端;领导协调终端,用于接收来自各个数据库代理的数据库读写状态信息,在超过预定时限未接收到任意一个数据库读写状态信息,或接收到的任意一个数据库读写状态信息为异常时,确定数据库集群中存在单点故障。
一种数据库集群单点故障的监控方法,包括:基于分布式协调机制的领导协调终端,接收与数据库集群中的数据库对应设置的数据库代理发送的数据库读写状态信息;领导协调终端在超过预定时限未接收到任意一个数据库读写状态信息、或接收到的任意一个数据库读写状态信息为异常时,确定数据库集群中存在单点故障。
根据本申请实施例提供的技术方案,通过数据库代理定时检测数据库集群中对应数据库的读写状态,基于分布式协调机制的领导协调终端根据来自数据库代理的数据库读写状态信息,对数据库集群中的单点故障进行识别,能够高效、可靠地识别数据库集群中的单点故障,从而能够解决现有技术中,分布式MySQL数据库单点故障的解决方案中存在的效率低下的问题。相比于现有技术,本申请实施例提供的技术方案操作简便、监控结果有效可靠。
本申请的其它特征和优点将在随后的说明书中阐述,并且,部分地从说明书中变得显而易见,或者通过实施本申请而了解。本申请的目的和其他优点可通过在所写的说明书、权利要求书、以及附图中所特别指出的结构来实现和获得。
附图说明
图1为现有技术中数据库集群的结构示意图;
图2为本申请实施例提供的数据库集群单点故障的监控系统的结构框图;
图3为本申请实施例提供的数据库集群单点故障的监控方法的流程图;
图4为图2中基于分布式协调机制的领导协调终端的工作流程图;
图5为本申请实施例具体实施的场景示意图。
具体实施方式
以下结合附图对本申请的实施例进行说明,应当理解,此处所描述的实施例仅用于说明和解释本申请,并不用于限定本申请。
针对现有技术中MySQL数据集群库单点故障的解决方案中存在的效率低下、数据安全性差、系统稳定性差的问题,本申请实施例提供了一种对数据库集群中的单点故障进行监控的方案,以解决至少一个上述问题。
在本申请实施例提供的方案中,设置与数据库集群中的数据库相对应的数据库代理,对应设置的数据库和数据库代理位于同一服务器上,设置至少三个基于分布式协调机制的协调终端,其中包括一个领导协调终端、其余为从属协调终端,每个数据库代理中都保存各个协调终端的IP地址和端口。数据库代理定期检测对应数据库的读写状态,并将检测结果上报给领导协调终端,领导协调终端在超过预定时限未接收到任意一个数据库的读写状态、或接收到的任意一个数据库读写状态信息为异常时,确定数据库集群中存在单点故障,能够通过由若干个数据库代理和至少三个协调终端构成的分布式结构,根据各数据库的读写状态信息来识别单点故障,从而能够简便、高效、可靠地识别数据库集群中的单点故障。
在本申请实施例的优选实施例中,还能够通过领导协调终端根据各数据库的数据更新状况,指示数据库代理完成主从数据库的切换操作、以及主从数据库之间的数据同步操作,在该分布式结构中,数据库代理仅对数据库的读写状态进行设置,不对数据库中的其他数据进行操作,能够保障数据安全性;基于分布式协调机制的协调终端,能够在领导协调终端发生故障时,自动选举出新的领导协调终端,能够保障系统的稳定性和可靠性;从而能够解决现有技术中,MySQL数据库集群单点故障的解决方案中存在的效率低下、数据安全性差、系统稳定性差的问题。
下面对本申请实施例进行详细说明。
图2中示出了本申请实施例提供的数据库集群单点故障的监控系统的结构框图,数据库集群(X1、X2、…、Xt)中包括若干个数据库,数据库包括主库XM或从库XS,如图2所示,该系统包括:多个数据库代理221、222、…、22t,由至少三个基于分布式协调机制的协调终端211、212、…、21n构成的协调集群21,协调集群21中包括一个领导协调终端21L、其余为从属协调终端21F,其中n为奇数;一个数据库代理22i与数据库集群中的一个数据库Xi对应设置在一台服务器上,每个数据库代理22i中均保存各个协调终端的地址。
图3中示出了图2所示系统的工作流程图,如图3所示,图2所示系统的工作原理包括如下处理步骤:
步骤31、数据库代理22i定时检测对应数据库的读写状态,并将检测得到的数据库读写状态信息发送给领导协调终端21L
步骤32、领导协调终端21L接收来自各个数据库代理的数据库读写状态信息,在超过预定时限未接收到任意一个数据库读写状态信息,或接收到的任意一个数据库读写状态信息为异常时,确定数据库集群中存在单点故障。
根据图2所示系统及其工作原理,通过数据库代理定时检测数据库集群中对应数据库的读写状态,基于分布式协调机制的领导协调终端根据来自数据库代理的数据库读写状态信息,对数据库集群中的单点故障进行识别,能够高效、可靠地识别数据库集群中的单点故障,从而能够解决现有技术中,分布式MySQL数据库单点故障的解决方案中存在的效率低下的问题。
以下处理过程为图2所示系统的优选实施方式的工作流程,具体包括:
步骤一、与主库XM对应的数据库代理在主库中创建主库测试表,在定时能够向主库测试表中写入一条记录、并从中读取一条记录,并且能够与主库XM的端口ping通时,确定主库XM的读写状态正常;
与从库XS相对应的数据库代理在从库XS中创建测试表,在定时能够从从库测试表中读取一条记录,并且能够与从库XS的端口ping通时,确定从库XS的读写状态正常;
步骤二、各数据库代理在预定的通信时刻到来时,将检测到的对应数据库的读写状态信息上报给领导协调终端21L
步骤三、领导协调终端21L判断是否超过预定时限未接收到任意一个所述数据库读写状态信息,或接收到的任意一个数据库读写状态信息为异常,在判断超过预定期限未收到主库XM读写状态信息,或者主库XM的读写状态信息为异常的情况下,处理进行到步骤四,在判断接收到的从库XS的读写状态信息为异常的情况下,处理进行到步骤十四;
步骤四、领导协调终端21L确定主库XM发生单点故障,将发生单点故障的主库XM标记为旧主库X’M,通知与读写状态信息为正常的从库XS相连接的数据库代理上报所述从库XS的数据更新状况;
步骤五、与从库XS对应的数据库代理根据来自领导协调终端21L的通知,获取对应从库XS的数据更新状况信息,将获取到的从库XS数据更新状况信息发送给领导协调终端21L
步骤六、领导协调终端21L根据各数据库代理上报的从库XS的数据更新状况信息,将数据更新数量最多的从库XS确定为新主库XM,指示与新主库XM对应的数据库代理将新主库XM的数据读写状态设置为可读可写;
步骤七、与新主库XM对应的数据库代理根据领导协调终端21L的指示,将对应新主库XM的数据读写状态设置为可读可写;
步骤八、领导协调终端21L将新主库XM的数据更新状况信息发送给与其它从库XS相连接的数据库代理;
步骤九、与从库XS相连接的数据库代理根据来自领导协调终端21L的新主库XM的数据更新状况信息、以及对应从库XS的数据更新状况信息,确定对应从库XS中缺乏的数据,从新主库XM中读取所确定缺乏的数据、并将读取的数据存入到对应从库XS中;
步骤十、领导协调终端21L在能够与旧主库X’M对应的数据库代理通信的情况下,指示与旧主库X’M对应的数据库代理将旧主库X’M的读写状态设置为只读,并上报旧主库X’M中的数据更新状况信息;
步骤十一、与旧主库X’M对应的数据库代理根据来自领导协调终端21L的指示,将对应旧主库X’M的读写状态设置为只读,获取对应旧主库X’M的数据更新状况信息,将获取到的旧主库X’M数据更新状况信息发送给领导协调终端21L
步骤十二、领导协调终端21L将接收到的旧主库X’M的数据更新状况信息发送给其它各数据库代理;
步骤十三、与新主库XM对应的数据库代理根据来自领导协调终端21L的旧主库X’M的数据更新状况信息、以及对应的新主库XM的数据更新状况信息,确定对应的新主库XM中缺乏的数据,从旧主库X’M中读取所确定缺乏的数据、并将读取的数据存入到对应新主库XM中;
与从库XS对应的数据库代理根据来自领导协调终端21L的旧主库X’M的数据更新状况信息、以及对应从库XS的数据更新状况信息,确定对应从库XS中缺乏的数据,从旧主库X’M中读取所确定缺乏的数据、并将读取的数据存入到对应从库XS中,处理结束。
步骤十四、领导协调终端21L在接收收到上报的从库XS读写状态信息为异常的情况下,确定从库XS发生单点故障,指示与发生单点故障的从库XS对应的数据库代理将该从库XS的读写状态设置为不可用;
步骤十五、与发生单点故障的从库XS相对应的数据库代理根据来自领导协调终端21L的指示将相对应的从库XS的读写状态设置为不可用,处理结束。
通过上述处理过程,领导协调终端21L能够实时高效地识别出主库XM或从库XS发生的单点故障,在主库XM发生单点故障的情况下,将从库XS中数据更新数量最多的从库XS确定为新的主库XM,指示与新主库XM对应的数据库代理完成从库XS切换为主库XM的操作;并通知与从库XS对应的各个数据库代理,根据新主库XM的数据更新状况补齐对应从库XS中缺乏的数据,在旧主库XM能够通信的情况下,通知其他数据库代理根据旧主库XM的数据更新状况补齐对应数据库中缺乏的数据,从而能够自动高效地完成数据库集群中单点故障下主从库XS的切换、以及主从数据库的数据同步处理。在本实施例提供的优选实施方式中,数据库代理仅根据领导协调的指示对数据库的读写状态进行设置,不对数据库中的其他数据进行操作,能够保障数据安全性。
以下对图2中分布式协调集群21的工作原理进行说明。
图4示出了图2所示系统中基于分布式协调机制的领导协调终端的工作流程图,如图4所示,领导协调终端的工作流程包括如下处理过程:
步骤41、领导协调终端接收与数据库集群中的数据库对应设置的数据库代理发送的数据库读写状态信息;
步骤42、领导协调终端在超过预定时限未接收到任意一个数据库读写状态信息、或接收到的任意一个数据库读写状态信息为异常时,确定数据库集群中存在单点故障。
基于分布式协调机制的领导协调终端,能够根据接收到的数据库的读写状态信息来识别数据库集群的单点故障,从而能够高效可靠地识别数据库集群的单点故障。
以下处理过程为协调集群21的优选实施方式的工作流程,具体包括:
步骤一、领导协调终端21L与其他各从属协调终端21F进行通信,在能够与超过半数以上的从属协调终端21F进行正常通信的情况下,处理进行到步骤二,在不能与全部从属协调终端21F通信的情况下,处理进行到步骤九;
步骤二、领导协调终端21L接收各个数据库代理发送的数据库读写状态信息;将接收到的数据库读写状态信息发送给各个从属协调终端21F
步骤三、领导协调终端21L判断是否超过预定时限未接收到任意一个数据库的读写状态信息、或接收到的数据库读写状态信息为异常,在判断超过预定时限未接收到主库的读写状态信息、或接收到的主库读写状态信息为异常,处理进行到步骤四,在判断超过预定时限未接收到从库的读写状态信息、或接收到的从库读写状态信息为异常,处理进行到步骤八;
步骤四、领导协调终端21L确定主库发生单点故障,将发生单点故障的主库标记为旧主库,通知与读写状态信息正常的从库对应的数据库代理上报从库的数据更新状况信息;
步骤五、领导协调终端21L根据各数据库代理上报的从库的数据更新状况信息,将数据更新数量最多的从库确定为新主库,指示与新主库对应的数据库代理将新主库的数据读写状态设置为可读可写;将各数据库代理上报的从库的数据更新状况信息发送给各个从属协调终端21F
步骤六、领导协调终端21L将新主库的数据更新状况信息发送给与从库对应的数据库代理,以使与从库对应的数据库代理根据新主库的数据更新状况信息,读取从库中缺乏的数据;
步骤七、领导协调终端21L在能够与旧主库对应的数据库代理通信的情况下,指示与旧主库对应的数据库代理将旧主库的读写状态设置为只读、上报旧主库中的数据更新状况信息,并将与旧主库对应的数据库代理上报的旧主库的数据更新状况信息发送给与新主库对应的数据库代理和与从库对应的数据库代理;将旧主库的数据更新状况信息发送给各个从属协调终端21F
步骤八、领导协调终端21L确定从库发生单点故障,指示与发生单点故障的从库对应的数据库代理将该从库的读写状态设置为不可用;
步骤九、各从属协调终端21F之间基于分布式协调机制进行通信,选举出新的领导协调终端21’L
步骤十、新的领导协调终端21’L将自身的IP地址和端口号发送给每一个数据库代理,处理返回步骤一。
图2中所示的基于分布式协调机制的协调集群,在超过半数以上的协调终端之间能够通信时就能够可靠稳定的运行,并且在领导协调终端发生故障、与其他从属协调终端之间不能通信时,从属协调终端之间基于分布式协调机制进行通信,选举出新的领导协调终端,该新的领导协调终端面向数据库代理进行通信,从而能够保障图2所示监控系统的运行稳定性,相比与现有技术,能够提高监控数据库集群单点故障的稳定性和可靠性。具体地,协调集群在具体实施的过程中,可采用基于Paxos协议的Chubby实例,或者采用基于Zab协议的Zookeeper实例。
下面对本申请实施例具体实施的情况进行说明。
图5示出了本申请实施例具体实施的场景示意图,数据库集群中的主库拆分为2个主库XM1中和主库XM2,主库XM1中和主库XM2中的数据不交叉,主库XM1的从库为从库XS1至从库XS5,主库XM2的从库为从库XS6至从库XS7,数据库集群构成数据库集群(DBC,DataBase Cluster),2个主库XM和5个从库被部署在三个的机房中,主库XM1和从库XS1至从库XS3部署在机房A中,从库XS4和从库XS5部署在机房B中,主库XM2和从库XS6、从库XS7部署在机房C中,各数据库均为MySQL实例,对每个数据库对应设置数据库代理Agent,对应设置的Agent和数据库位于同一个服务器中,3个基于分布式协调机制的协调终端构成协调集群(DCSC,Distributed CooperationServices Cluster),DCSC中包括一个领导协调终端(Leader)、2个从属协调终端(Follower),每个协调终端均为Zookeeper实例,每个Agent中均保持各个协调终端的IP地址和端口号。
图5所示系统启动时,先分别启动DBC和DCSC,与数据库位于同一服务器上的Agent后续启动,图5所示系统的工作流程包括如下处理过程:
步骤一、各Agent读取相连接的数据库的IP、通信端口,将读取到的数据库的IP、通信端口号发送给DCSC的Leader;
步骤二、Leader记录接收到的各数据库的IP、通信端口;
步骤三、与主库相对应的AgentM1、AgentM2分别在相对应的主库XM1、XM2中创建主库测试表,在定时能够向主库测试表中写入一条记录、从中读取一条记录,并且和主库的端口ping通时,确定主库的读写状态正常;与从库相连接的AgentS1~AgentS7分别在相对应的从库中创建从库测试表,在定时能够从从库测试表中读取一条记录、并与从库的端口ping通时,确定从库的读写状态正常;
步骤四、各Agent在预定的通信时刻到来时,将检测得到的对应数据库的读写状态信息上报给Leader;
步骤五、Leader判断超过预定期限未收到AgentM1发送的主库XM1的读写状态信息,并且AgentS2发送的从库XS2的读写状态信息为异常;
步骤六、Leader将主库XM1标记为旧主库XM’1,通知与正常存活的(即读写状态信息为正常)的从库XS1、从库XS3、从库XS4、从库XS5相连接的AgentS1、AgentS3、AgentS4、AgentS5上报从库的数据同步点记录,并指示与从库XS2相连接的AgentS2将从库XS2的读写状态设置为不可用;
步骤七、AgentS1读取从库XS1的数据点同步记录为100条,AgentS3读取从库XS3的数据点同步记录为105条,AgentS4读取从库XS4的数据点同步记录为108条,AgentS5读取从库XS5的数据点同步记录为110条,AgentS1、AgentS3、AgentS4、AgentS5将读取的数据点同步记录上报给Leader;AgentS2根据Leader的指示,将从库XS2的读写状态设置为不可用;
步骤八、Leader根据与上报的从库XS的数据同步点记录,将同步点位置最大的从库XS5确定为新主库XM;
步骤九、Leader指示AgentS5将从库XS5的读写状态设置为可读可写;
步骤九、AgentS5根据Leader的指示,将从库XS5的读写状态设置为可读可写;
步骤十、Leader将从库XS5的数据同步点记录110条发送给AgentS1、AgentS3、AgentS4;
步骤十一、AgentS1、AgentS3、AgentS4分别根据从库XS5的数据点同步记录,AgentS1从从库XS5中读取101条至110条数据,AgentS3从从库XS5中读取106条至110条数据,AgentS4从从库XS5中读取109条至110条数据;
步骤十二、旧主库XM’1重启后,AgentM1与Leader之间重新发起通信,Leader查找与AgentM1相连接的数据库的标记,发现与AgentM1相连接的数据库为旧主库XM’1,指示AgentM1将旧主库XM’1的读写状态设置为只读、并上报旧主库XM’1中的数据同步点记录;
步骤十三、AgentM1根据来自Leader的指示,将旧主库XM’1的读写状态设置为只读,在旧主库XM’1中的数据同步点记录可读取的情况下,读取旧主库XM’1中的数据同步点记录为120条,将读取的数据同步点记录为120上报给Leader;
步骤十四、Leader将AgentM1上报的数据同步点记录发送给AgentS1、AgentS3、AgentS4;
步骤十五、AgentS1、AgentS3、AgentS4分别根据旧主库XM’1的数据点同步记录,AgentS1、AgentS3、AgentS4从旧主库XM’1读取111条至120条数据。
相类似地,如果主库2及其从库发生单点故障,也可以根据上述处理过程完成主从数据库的切换及数据同步处理。
通过如图6所示的系统及其工作过程,对应将主库拆分为多套数据库的数据库集群中的单点故障,能够及时高效地自动完成数据库的切换、以及数据同步操作,根据经验统计情况,单套库的数据库集群可以在秒单位级别完成切换,对于将主库拆分为16套库的数据库集群,能够在几十秒级别完成主从数据库的切换,并且,数据库代理仅根据领导协调终端的指令对数据库的读写状态进行设置,不对数据库中的数据安全造成威胁,各协调终端基于分布式协调机制构成可靠的分布式协调集群,能够保障系统的稳定性。
综上所述,本申请实施例提供的数据库集群单点故障的监控系统及其工作原理,通过由数据库代理和基于分布式协调机制的协调终端构成的分布式结构,能够自动、高效、安全、稳定、可靠地识别数据库集群的单点故障、实现主备数据库的切换、以及各数据库之间的数据同步操作。相比与现有技术中通过人工识别以及通过单点监控端来识别单点故障,能够提高识别单点故障的效率、有效地保障数据库中数据的安全性、提高对单点故障处理的可靠性和稳定性。
显然,本领域的技术人员可以对本申请进行各种改动和变型而不脱离本申请的精神和范围。这样,倘若本申请的这些修改和变型属于本申请权利要求及其等同技术的范围之内,则本申请也意图包含这些改动和变型在内。

Claims (12)

1.一种数据库集群单点故障的监控系统,应用于包括若干个数据库的数据库集群中,所述数据库包括主库或从库,其特征在于,所述监控系统包括:
若干个数据库代理,至少三个基于分布式协调机制相互通信的协调终端,其中,至少三个所述协调终端中包括一个领导协调终端;一个所述数据库代理与所述数据库集群中的一个数据库对应设置在一台服务器上,每个所述数据库代理中均保存各个所述协调终端的地址;
所述数据库代理,用于定时检测对应数据库的读写状态,并将检测得到的数据库读写状态信息发送给所述领导协调终端;
所述领导协调终端,用于接收来自各个数据库代理的数据库读写状态信息,在超过预定时限未接收到任意一个所述数据库读写状态信息,或接收到的任意一个数据库读写状态信息为异常时,确定所述数据库集群中存在单点故障。
2.根据权利要求1所述的系统,其特征在于,所述领导协调终端,具体用于:在超过预定时限未接收到所述主库的读写状态信息或接收到的所述主库的读写状态信息为异常时,确定所述主库发生单点故障,将发生单点故障的所述主库标记为旧主库,通知与读写状态信息正常的从库对应的数据库代理上报所述从库的数据更新状况信息;根据各所述数据库代理上报的所述从库的数据更新状况信息,将数据更新数量最多的从库确定为新主库,指示与所述新主库对应的数据库代理将所述新主库的数据读写状态设置为可读可写;
与所述从库对应的数据库代理,根据来自所述领导协调终端的所述通知,获取对应从库的数据更新状况信息,将获取到的从库数据更新状况信息发送给所述领导协调终端;在接收到来自所述领导协调终端的所述指示的情况下,将对应从库的数据读写状态设置为可读可写。
3.根据权利要求2所述的系统,其特征在于,所述领导协调终端,还用于:将所述新主库的数据更新状况信息发送给与所述从库对应的数据库代理;
与所述从库对应的数据库代理,还用于根据来自所述领导协调终端的所述新主库的数据更新状况信息、以及对应从库的数据更新状况信息,确定对应从库中缺乏的数据,从所述新主库中读取所确定缺乏的数据、并将读取的数据存入到对应从库中。
4.根据权利要求3所述的系统,其特征在于,所述领导协调终端,还用于:在能够与所述旧主库对应的数据库代理通信的情况下,指示与所述旧主库对应的数据库代理将所述旧主库的读写状态设置为只读、上报所述旧主库中的数据更新状况信息,并将接收到的所述旧主库的数据更新状况信息发送给与所述新主库对应的数据库代理和与所述从库对应的数据库代理;
与所述旧主库对应的数据库代理,还用于:根据来自所述领导协调终端的所述指示,将对应所述旧主库的读写状态设置为只读,获取对应所述旧主库的数据更新状况信息,将获取到的旧主库数据更新状况信息发送给所述领导协调终端;
与所述新主库对应的数据库代理,还用于:根据来自所述领导协调终端的所述旧主库的数据更新状况信息、以及对应的所述新主库的数据更新状况信息,确定对应的所述新主库中缺乏的数据,从所述旧主库中读取所确定缺乏的数据、并将读取的数据存入到对应所述新主库中;
与所述从库对应的数据库代理,还用于:根据来自所述领导协调终端的所述旧主库的数据更新状况信息、以及对应从库的数据更新状况信息,确定对应从库中缺乏的数据,从所述旧主库中读取所确定缺乏的数据、并将读取的数据存入到对应从库中。
5.根据权利要求1所述的系统,其特征在于,所述领导协调终端,还用于:在接收到的所述从库的读写状态信息为异常时,确定所述从库发生单点故障,指示与该从库对应的数据库代理将该从库的读写状态设置为不可用;
与所述从库对应的数据库代理,还用于:在接收到来自所述领导协调终端的所述指示的情况下,将对应从库的读写状态设置为不可用。
6.根据权利要求4所述的系统,其特征在于,至少三个所述协调终端中还包括从属协调终端;
所述领导协调终端,还用于:将来自各所述数据库代理的数据库读写状态信息、数据库更新状态信息、以及所述新主库的标识发送给每一个所述从属协调终端;
所述从属协调终端,具体用于:接收并存储来自所述领导协调终端的数据库读写状态信息、数据库更新状态信息、以及所述新主库的标识;在所述领导协调终端发生故障时,基于所述分布式协调机制与其它所述从属协调终端通信,选举出新的领导协调终端;在被选举成为新的领导协调终端的情况下,将所述新领导协调终端的IP地址和端口号发送给每一个所述数据库代理。
7.一种数据库集群单点故障的监控方法,其特征在于,包括:
基于分布式协调机制的领导协调终端,接收与数据库集群中的数据库对应设置的数据库代理发送的数据库读写状态信息;
所述领导协调终端在超过预定时限未接收到任意一个所述数据库读写状态信息、或接收到的任意一个数据库读写状态信息为异常时,确定所述数据库集群中存在单点故障。
8.根据权利要求7所述的方法,其特征在于,所述领导协调终端在超过预定时限未接收到任意一个所述数据库读写状态信息、或接收到的任意一个数据库读写状态信息为异常时,确定所述数据库集群中存在单点故障,具体包括:
所述领导协调终端在超过预定时限未接收到所述主库的读写状态信息、或接收到的所述主库的读写状态信息为异常时,确定所述主库发生单点故障,将发生单点故障的所述主库标记为旧主库,通知与读写状态信息正常的从库对应的数据库代理上报所述从库的数据更新状况信息;
所述领导协调终端根据各所述数据库代理上报的所述从库的数据更新状况信息,将数据更新数量最多的从库确定为新主库,指示与所述新主库对应的数据库代理将所述新主库的数据读写状态设置为可读可写。
9.根据权利要求8所述的方法,其特征在于,所述方法还包括:
所述领导协调终端将所述新主库的数据更新状况信息发送给与所述从库对应的数据库代理,以使与所述从库对应的数据库代理根据所述新主库的数据更新状况信息,读取所述从库中缺乏的数据。
10.根据权利要求9所述的方法,其特征在于,所述方法还包括:
所述领导协调终端在能够与所述旧主库对应的数据库代理通信的情况下,指示与所述旧主库对应的数据库代理将所述旧主库的读写状态设置为只读、上报所述旧主库中的数据更新状况信息,并将与所述旧主库对应的数据库代理上报的所述旧主库的数据更新状况信息发送给与所述新主库对应的数据库代理和与所述从库对应的数据库代理。
11.根据权利要求7所述的方法,其特征在于,所述领导协调终端在超过预定时限未接收到任意一个所述数据库读写状态信息、或接收到的任意一个数据库读写状态信息为异常时,确定所述数据库集群中存在单点故障,还包括:
在接收到的所述从库的读写状态信息为异常时,确定所述从库发生单点故障,指示与发生单点故障的从库对应的数据库代理将该从库的读写状态设置为不可用。
12.根据权利要求10所述的方法,其特征在于,所述方法还包括:
所述领导协调终端将来自各所述数据库代理的数据库读写状态信息、数据库更新状态信息、以及所述新主库的标识发送给基于分布式协调机制与所述领导协调终端通信的每一个从属协调终端;
所述从属协调终端接收并存储来自所述领导协调终端的数据库读写状态信息、数据库更新状态信息、以及所述新主库的标识;在所述领导协调终端发生故障时,基于所述分布式协调机制与其它所述从属协调终端通信,选举出新的领导协调终端;在被选举成为新的领导协调终端的情况下,将所述新的领导协调终端的IP地址和端口号发送给每一个所述数据库代理。
CN201210148938.9A 2012-05-14 2012-05-14 数据库集群单点故障的监控系统及方法 Active CN103425645B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201210148938.9A CN103425645B (zh) 2012-05-14 2012-05-14 数据库集群单点故障的监控系统及方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201210148938.9A CN103425645B (zh) 2012-05-14 2012-05-14 数据库集群单点故障的监控系统及方法

Publications (2)

Publication Number Publication Date
CN103425645A true CN103425645A (zh) 2013-12-04
CN103425645B CN103425645B (zh) 2017-03-01

Family

ID=49650407

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201210148938.9A Active CN103425645B (zh) 2012-05-14 2012-05-14 数据库集群单点故障的监控系统及方法

Country Status (1)

Country Link
CN (1) CN103425645B (zh)

Cited By (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104504130A (zh) * 2014-12-31 2015-04-08 天津南大通用数据技术股份有限公司 应用于分布式数据库的解决2pc模型单点故障问题的方法
CN105337780A (zh) * 2015-12-01 2016-02-17 迈普通信技术股份有限公司 一种服务器节点配置方法及物理节点
CN105528373A (zh) * 2014-10-21 2016-04-27 阿里巴巴集团控股有限公司 数据库故障处理方法、装置、系统及服务器
CN106156318A (zh) * 2016-07-05 2016-11-23 武汉斗鱼网络科技有限公司 一种实现多节点数据库高可用的系统及方法
CN106982148A (zh) * 2016-01-19 2017-07-25 中国移动通信集团浙江有限公司 一种服务器宕机的监测方法、装置及系统
CN107153660A (zh) * 2016-03-04 2017-09-12 福建天晴数码有限公司 分布式数据库系统的故障检测处理方法及其系统
WO2017162173A1 (zh) * 2016-03-22 2017-09-28 中兴通讯股份有限公司 云服务器集群建立连接的方法和装置
CN107426038A (zh) * 2017-09-12 2017-12-01 郑州云海信息技术有限公司 一种采集数据的分布式集群系统及数据采集方法
CN108959604A (zh) * 2018-07-13 2018-12-07 浙江彩虹鱼科技有限公司 维护数据库集群的方法、装置及计算机可读存储介质
CN108984569A (zh) * 2017-06-05 2018-12-11 中兴通讯股份有限公司 数据库切换方法、系统和计算机可读存储介质
CN109947772A (zh) * 2018-09-07 2019-06-28 网联清算有限公司 数据库自动切换方法、装置、存储介质及计算机设备
CN110427353A (zh) * 2019-06-27 2019-11-08 华迪计算机集团有限公司 数据库服务器集群读写分离设置的方法及装置
CN111930570A (zh) * 2020-08-17 2020-11-13 湖南快乐阳光互动娱乐传媒有限公司 一种多机房数据库高可用的处理系统及处理方法
CN112000735A (zh) * 2020-08-05 2020-11-27 中国邮政储蓄银行股份有限公司 一种数据处理方法、装置、系统
CN112035312A (zh) * 2020-07-22 2020-12-04 大箴(杭州)科技有限公司 一种检测Kafka集群中Leader进程的可用状态方法及装置
CN113051349A (zh) * 2021-04-02 2021-06-29 广东美电贝尔科技集团股份有限公司 一种执勤系统数据同步方法
CN113590635A (zh) * 2021-08-23 2021-11-02 中国银行股份有限公司 海外多银行的数据分析系统及方法
CN113761051A (zh) * 2020-07-01 2021-12-07 北京沃东天骏信息技术有限公司 消息推送方法、数据获取方法、装置、系统、设备和介质

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101635638A (zh) * 2008-07-25 2010-01-27 中兴通讯股份有限公司 一种容灾系统及其容灾方法
CN101876924A (zh) * 2009-04-30 2010-11-03 升东网络科技发展(上海)有限公司 数据库故障自动检测及转移方法
US20110099420A1 (en) * 2009-10-26 2011-04-28 Macdonald Mcalister Grant Alexander Failover and recovery for replicated data instances

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101635638A (zh) * 2008-07-25 2010-01-27 中兴通讯股份有限公司 一种容灾系统及其容灾方法
CN101876924A (zh) * 2009-04-30 2010-11-03 升东网络科技发展(上海)有限公司 数据库故障自动检测及转移方法
US20110099420A1 (en) * 2009-10-26 2011-04-28 Macdonald Mcalister Grant Alexander Failover and recovery for replicated data instances

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
宣城网盟: "MySQL Proxy", 《HTTP://BAIKE.BAIDU.COM/HISTORY/MYSQL%20PROXY/24599689》, 26 October 2011 (2011-10-26), pages 1 - 2 *

Cited By (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105528373A (zh) * 2014-10-21 2016-04-27 阿里巴巴集团控股有限公司 数据库故障处理方法、装置、系统及服务器
CN104504130A (zh) * 2014-12-31 2015-04-08 天津南大通用数据技术股份有限公司 应用于分布式数据库的解决2pc模型单点故障问题的方法
CN105337780B (zh) * 2015-12-01 2018-09-18 迈普通信技术股份有限公司 一种服务器节点配置方法及物理节点
CN105337780A (zh) * 2015-12-01 2016-02-17 迈普通信技术股份有限公司 一种服务器节点配置方法及物理节点
CN106982148A (zh) * 2016-01-19 2017-07-25 中国移动通信集团浙江有限公司 一种服务器宕机的监测方法、装置及系统
CN106982148B (zh) * 2016-01-19 2020-02-18 中国移动通信集团浙江有限公司 一种服务器宕机的监测方法、装置及系统
CN107153660A (zh) * 2016-03-04 2017-09-12 福建天晴数码有限公司 分布式数据库系统的故障检测处理方法及其系统
CN107153660B (zh) * 2016-03-04 2020-03-17 福建天晴数码有限公司 分布式数据库系统的故障检测处理方法及其系统
WO2017162173A1 (zh) * 2016-03-22 2017-09-28 中兴通讯股份有限公司 云服务器集群建立连接的方法和装置
CN106156318B (zh) * 2016-07-05 2022-08-16 武汉斗鱼网络科技有限公司 一种实现多节点数据库高可用的系统及方法
CN106156318A (zh) * 2016-07-05 2016-11-23 武汉斗鱼网络科技有限公司 一种实现多节点数据库高可用的系统及方法
CN108984569A (zh) * 2017-06-05 2018-12-11 中兴通讯股份有限公司 数据库切换方法、系统和计算机可读存储介质
CN107426038A (zh) * 2017-09-12 2017-12-01 郑州云海信息技术有限公司 一种采集数据的分布式集群系统及数据采集方法
CN108959604A (zh) * 2018-07-13 2018-12-07 浙江彩虹鱼科技有限公司 维护数据库集群的方法、装置及计算机可读存储介质
CN108959604B (zh) * 2018-07-13 2020-11-10 浙江彩虹鱼科技有限公司 维护数据库集群的方法、装置及计算机可读存储介质
CN109947772A (zh) * 2018-09-07 2019-06-28 网联清算有限公司 数据库自动切换方法、装置、存储介质及计算机设备
CN110427353A (zh) * 2019-06-27 2019-11-08 华迪计算机集团有限公司 数据库服务器集群读写分离设置的方法及装置
CN110427353B (zh) * 2019-06-27 2022-07-26 华迪计算机集团有限公司 数据库服务器集群读写分离设置的方法及装置
CN113761051A (zh) * 2020-07-01 2021-12-07 北京沃东天骏信息技术有限公司 消息推送方法、数据获取方法、装置、系统、设备和介质
CN112035312A (zh) * 2020-07-22 2020-12-04 大箴(杭州)科技有限公司 一种检测Kafka集群中Leader进程的可用状态方法及装置
CN112000735A (zh) * 2020-08-05 2020-11-27 中国邮政储蓄银行股份有限公司 一种数据处理方法、装置、系统
CN111930570A (zh) * 2020-08-17 2020-11-13 湖南快乐阳光互动娱乐传媒有限公司 一种多机房数据库高可用的处理系统及处理方法
CN113051349A (zh) * 2021-04-02 2021-06-29 广东美电贝尔科技集团股份有限公司 一种执勤系统数据同步方法
CN113590635A (zh) * 2021-08-23 2021-11-02 中国银行股份有限公司 海外多银行的数据分析系统及方法

Also Published As

Publication number Publication date
CN103425645B (zh) 2017-03-01

Similar Documents

Publication Publication Date Title
CN103425645A (zh) 数据库集群单点故障的监控系统及方法
CN103152414B (zh) 一种基于云计算的高可用系统
CN103199972B (zh) 基于soa、rs485总线实现的双机热备份切换方法及热备份系统
CN202798798U (zh) 基于云计算技术的高可用系统
CN100426751C (zh) 保证集群系统中配置信息一致的方法
CN106357787A (zh) 一种存储容灾控制系统
CN101079896B (zh) 一种构建并行存储系统多可用性机制并存架构的方法
CN103346903A (zh) 一种双机备份的方法和装置
CN111966467B (zh) 基于kubernetes容器平台灾备的方法及装置
CN104252485A (zh) 一种数据库管理平台
CN101483540A (zh) 一种高端数据通信设备中的主备倒换方法
CN104252500A (zh) 一种数据库管理平台的故障修复方法和装置
CN105306272A (zh) 信息系统故障场景信息收集方法及系统
CN106330523A (zh) 一种集群服务器容灾系统、方法和服务器节点
CN105068763B (zh) 一种针对存储故障的虚拟机容错系统和方法
CN108052371B (zh) 基于虚拟化技术的铁路tdcs/ctc系统及其应用
CN109768884A (zh) 通信系统及其高可用性的实现方法、装置和计算机设备
CN107463468A (zh) 缓存管理方法及其设备
CN107623703A (zh) 全局事务标识gtid的同步方法、装置及系统
CN109921942A (zh) 云平台切换控制方法、装置、系统及电子设备
CN105893176B (zh) 一种网络存储系统的管理方法和装置
CN100395962C (zh) 通信系统中设备的倒换方法及其系统
CN110399254A (zh) 一种服务器cmc双机热活方法、系统、终端及存储介质
TW202026879A (zh) 運用於資料中心的機櫃異常狀態的遠端排除方法(三)
CN107888491A (zh) Hsb备份系统及基于二层组网vrrp协议的ac双机热备方法

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