[发明专利]一种MySQL高可用性的实现方法在审
申请号: | 202111161444.X | 申请日: | 2021-09-30 |
公开(公告)号: | CN113849351A | 公开(公告)日: | 2021-12-28 |
发明(设计)人: | 王鹏凯 | 申请(专利权)人: | 紫光云技术有限公司 |
主分类号: | G06F11/14 | 分类号: | G06F11/14;G06F16/242;G06F16/27 |
代理公司: | 天津滨海科纬知识产权代理有限公司 12211 | 代理人: | 李彦彦 |
地址: | 300459 天津市滨海新区*** | 国省代码: | 天津;12 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 mysql 可用性 实现 方法 | ||
本发明提供了一种MySQL高可用性的实现方法,包括以下步骤;S1、搭建MySQL主从服务器;S2、应用系统分别创建与主从MySQL服务器的连接,并维护一个主服务器信息、状态的公共资源与连接的绑定关系,根据主服务器的状态去获取连接,应用系统即为后台服务器;S3、应用系统开启一个子进程,通过定时配置检测MySQL主从机器的活动状态;S4、当定时配置检测到主MySQL服务器恢复时,通过文件传输脚本从MySQL从服务器上同步数据文件到MySQL主服务器,并切换回步骤S2中的主机器状态。本发明有益效果:一种MySQL高可用性的实现方法可以有效利用MySQL自身支持的主从复制来保证数据的准确性,又可以通过自定义定时任务在主机器发生故障时,自动切换数据源,简单灵活的达成MySQL高可用的目的。
技术领域
本发明属于APP后端技术领域,尤其是涉及一种MySQL高可用性的实现方法。
背景技术
目前现有的应用系统使用MySQL进行数据存储时,往往会面对单机MySQL如果宕机致使整个系统瘫痪的问题,及时搭建MySQL主从,仅仅起到备份数据的作用,无法支持系统自动切换数据库,因此目前现有技术存在以下问题:MySQL主从同步,只能做到备份数据的作用,当主机器发生故障,系统无法自动切换数据库,从而瘫痪;MySQL cluster集群虽然能自动切换数据库,但是有诸多限制:不支持外键,数据行不能超过8K,部署、管理、配置很复杂,备份和恢复不方便等问题,因此亟需一种MySQL高可用性的实现方法。
发明内容
有鉴于此,本发明旨在提出一种MySQL高可用性的实现方法,提出了解决应用系统中对MySQL进行使用时高可用的需要提出的解决方案。
为达到上述目的,本发明的技术方案是这样实现的:
第一方面本方案公开了一种MySQL高可用性的实现方法,包括以下步骤;
S1、搭建MySQL主从服务器;
S2、应用系统分别创建与主从MySQL服务器的连接,并维护一个主服务器信息、状态的公共资源与连接的绑定关系,根据主服务器的状态去获取连接,应用系统即为后台服务器;
S3、应用系统开启一个子进程,通过定时配置检测MySQL主从机器的活动状态;
S4、当定时配置检测到主MySQL服务器恢复时,通过文件传输脚本从MySQL从服务器上同步数据文件到MySQL主服务器,并切换回步骤S2中的主机器状态。
进一步的,在步骤S2中,根据主服务器的状态去获取的连接即为与主MySQL服务器建立的连接。
进一步的,在步骤S3中,应用系统开启的子进程即为定时任务。
进一步的,在步骤S3中,当定时任务检测到MySQL主机器故障后,更新步骤S2中的公共资源即主机器的状态信息。
进一步的,在步骤S3中,更新的步骤S2中的公共资源即为主机器的状态信息。
进一步的,应用系统在访问MySQL主从服务器时只需要根据主机器状态选择对应的连接,保证了只要有一台机器还存活即可用,即实现了MySQL的高可用。
进一步的,在步骤S4中,还可以通过连接MySQL的后台服务器通过SQL指令进行数据同步。
第二方面本方案公开了一种电子设备,包括处理器以及与处理器通信连接,且用于存储所述处理器可执行指令的存储器,所述处理器用于执行第一方面所述的一种MySQL高可用性的实现方法。
第三方面本方案公开了一种服务器,包括至少一个处理器,以及与所述处理器通信连接的存储器,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述处理器执行,以使所述至少一个处理器执行第一方面所述的一种MySQL高可用性的实现方法。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于紫光云技术有限公司,未经紫光云技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202111161444.X/2.html,转载请声明来源钻瓜专利网。