[发明专利]一种自动恢复掉电的MariaDB Galera Cluster的方法有效
申请号: | 201611132006.X | 申请日: | 2016-12-09 |
公开(公告)号: | CN106844092B | 公开(公告)日: | 2020-02-11 |
发明(设计)人: | 陈林祥;田松 | 申请(专利权)人: | 武汉烽火信息集成技术有限公司 |
主分类号: | G06F11/14 | 分类号: | G06F11/14;G06F16/25 |
代理公司: | 42225 武汉智权专利代理事务所(特殊普通合伙) | 代理人: | 张凯 |
地址: | 430073 湖*** | 国省代码: | 湖北;42 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 自动 恢复 掉电 mariadbgaleracluster 方法 | ||
本发明公开了一种自动恢复掉电的MariaDB Galera Cluster的方法,MariaDB Galera Cluster是MariaDB数据库的同步多主集群,涉及云平台基础数据库领域,包括:当MariaDB Galera Cluster的节点掉电并上电后,上报所有节点的状态ID至服务发现集群中;遍历节点的状态ID,并判断当前状态ID的值是否为所有节点状态ID的值中最大,若是,则启动当前状态ID对应节点的服务,若否,则跳过;当最大值的状态ID对应的节点服务启动后,启动所有其它节点的服务。本发明能够快速恢复云平台基础数据库服务。
技术领域
本发明涉及云平台基础数据库领域,具体涉及一种自动恢复掉电的MariaDBGalera Cluster的方法。
背景技术
数据库是云平台的基础组件,如何保证数据库的高可靠性是云平台建设需重点专注的项目。为保证云平台运行的高效性,现如今普遍采用MariaDB Galera Cluster,MariaDB Galera Cluster是MariaDB数据库的同步多主集群,但数据库集群在全部掉电并再次上电后,数据库集群的功能无法自动恢复,需人工介入使数据库集群恢复,费时费力,且不符合现如今提倡的自动化社会的建设需求。
发明内容
针对现有技术中存在的缺陷,本发明的目的在于提供一种自动恢复掉电的MariaDB Galera Cluster的方法,能够快速恢复云平台服务。
为达到以上目的,本发明采取的技术方案是,包括:
当MariaDB Galera Cluster的节点掉电并上电后,上报所有节点的状态ID至服务发现集群中;
遍历节点的状态ID,并判断当前状态ID的值是否为所有节点状态ID的值中最大,若是,则启动当前状态ID对应节点的服务,若否,则跳过;
当最大值的状态ID对应的节点服务启动后,启动所有其它节点的服务。
在上述技术方案的基础上,状态ID的值通过全局事务ID获取。
在上述技术方案的基础上,所述节点的状态ID通过启动脚本上报至服务发现集群中。
在上述技术方案的基础上,待数据库守护脚本确定所有节点的状态ID均已上报至服务发现集群中后,开始依次遍历节点的状态ID。
在上述技术方案的基础上,对于执行非事务性操作时崩溃的MariaDB GaleraCluster:
所有节点的状态ID上报至服务发现集群中后,依次遍历节点的状态ID,当首次出现值为-1的状态ID,则启动该状态ID对应的节点的服务,执行数据库恢复服务,当成功恢复一个节点后,启动所有其它节点的服务。
在上述技术方案的基础上,所述服务发现集群为Etcd服务发现集群。
与现有技术相比,本发明的优点在于:当节点掉电并上电后,通过将节点的状态ID的值上报至Etcd服务发现集群中,比对找到状态ID的值最大的节点,并启动该节点的服务,然后启动所有其它节点的服务,从而自动恢复MariaDB Galera Cluster,且整个过程无需人工干预,便能快速恢复云平台基础数据库服务。
附图说明
图1为本发明一种自动恢复掉电的MariaDB Galera Cluster的方法的流程图。
具体实施方式
以下结合附图对本发明作进一步详细说明。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于武汉烽火信息集成技术有限公司,未经武汉烽火信息集成技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201611132006.X/2.html,转载请声明来源钻瓜专利网。