iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >京东MySQL数据库主从切换自动化
  • 884
分享到

京东MySQL数据库主从切换自动化

2024-04-02 19:04:59 884人浏览 薄情痞子
摘要

1. 产生背景随着京东业务的高速增长,数据的重要性对于京东来说重要程度不说自明,在信息时代,数据有着比人们更大的力量,数据库的价值可见一斑,数据库的存在为人们提供了更快的查询,那么为了更好地做到数据库的高可

1. 产生背景

随着京东业务的高速增长,数据的重要性对于京东来说重要程度不说自明,在信息时代,数据有着比人们更大的力量,数据库的价值可见一斑,数据库的存在为人们提供了更快的查询,那么为了更好地做到数据库的高可用,保证持续提供服务,简化DBA操作,节省数据库故障切换的时间,故开发此数据库主从切换自动化系统。

2. 实现原理

此系统基于MHA做数据库切换,结合京东数据库切换的特点,定制自己的切换系统。MHA(Master High Availability)目前在Mysql高可用方面是一个相对成熟的解决方案,它由日本DeNA公司Yoshinori Matsunobu开发,是一套优秀的作为mysql高可用性环境下故障切换和主从提升的高可用软件。在Mysql故障切换过程中,MHA能做到在0~30秒之内自动完成数据库的故障切换操作,并且在进行故障切换的过程中,MHA能在最大程度上保证数据的一致性,同时最大化挽回故障发生后的数据,结合zabbix监控报警,以达到真正意义上的高可用。三重检测,保证切换无误:zabbix检测,任务创建时检测,MHA检测。

3. 实现功能

此系统实现了死切(从库故障切换及回切,主库故障切换),活切(主库活切及主库回切),做到自动化、自助化、可视化切换。

4. 具体实现
4.1. 死切(故障切换)

当Zabbix自动监控系统检测到数据库故障时,会自动调故障切换程序,然后判断是主库故障,还是从库故障,分情况处理,所有的故障信息都可在DBS系统上查看

4.1.1 主库故障:

先在DBS系统上创建切换任务,另外DBA也可在故障切换页面批量添加故障主库IP,创建切换任务。然后相应DBA执行切换按钮,则会判断各种情况

4.1.1.1切换重要步骤及原则

l 探活,探活检测机制由select方式改为insert方式,这样可以包含实例夯住和硬盘只读的情况,如果没有存活的从库,则放弃本次操作并邮件和短信通知DBA手动处理。

l 选择新主库,先本地(先物理机后Docker,先连接数少,后QPS负载低),后异地(先物理机后DOCKER,先连接数少,后QPS负载低)原则选择目标实例

l 调MHA接口进行故障切换故障系统信息变更

a.MHA会优先使用上一步选出的从库做为新主库,否则会使用最新数据的从库提升为新主库,然后将所有其他的从库重新指向新主库。之后会调用域名切换接口,将原来故障主库下的域名,全部指向到新的主库IP上。如果MHA切换失败或MHA有告警信息,或者有域名未切换成功,都会使用邮件和短信通知DBA人工处理。

b.当MHA故障切换结束后,系统会将新主库的mysql.cnf配置文件中的read_only=1删除,并在新主库上执行reset salve all或stop slave指令。

c.调用zabbix主机改名接口,修改故障主库及新主库在zabbix监控系统中的名称。

d. 由于域名切换后非实时生效,存在时延,因此系统会对域名生效进行检查,如果2分钟内未生效,则会进行提示,需要DBA进行人工确认。

e. 最后,在资产库中更新集群信息,修改主从关系并进行数据库状态变更,更新故障信息表。同时,发送邮件和短信通知DBA故障切换完成。

f.活切可以支持多集群同时切换。

4.1.1.2 举例

例如有一主四从的集群,主库 10.66.66.66:3366故障,需要切换,如下:

京东MySQL数据库主从切换自动化

1.Zabbix自动创建任务,然后DBA执行切换

京东MySQL数据库主从切换自动化

2.选目标实例

假如例子中的4个从都是存活的,那么在此处会比较根据先本地,选出10.66.66.68:3366,10.66.66.69:3366,然后查连接数,都相同,则去查QPS,

然后比较QPS,选出QPS负载低的10.66.66.69:3366作为目标实例。

京东MySQL数据库主从切换自动化

3.切换完成结果

京东MySQL数据库主从切换自动化

4.切换的详细信息

京东MySQL数据库主从切换自动化

4.1.2从库故障(系统自动完成):4.1.2.1 切换原则

判断是否宕机实例没有域名,宕机实例设置为手动切换,宕机实例所在集群无其他正常运行实例,这些情况下会给相应的DBA发邮件及短信报警,需要DBA手动处理;

其他情况故障系统会自动处理,根据先本地(连接数少,QPS负载低),后异地(连接数少,QPS负载低)原则选择目标实例,进行域名切换,切换成功或失败都会发邮件及短信告知相应的DBA;

切换成功的从库,相应的DBA可以回切该实例。

4.1.2.2 举例

例如有一主四从的集群,从库 10.88.88.89:3366故障,需要切换,如下:

京东MySQL数据库主从切换自动化

zabbix会自动创建任务,并根据先本地后异地,然后查连接数,QPS原则,确定目标实例为10.88.88.88:3366,然后自动切换,DBA会在切换任务列表查看切换结果,鼠标悬停执行状态会显示切换的具体信息

京东MySQL数据库主从切换自动化

切换成功的任务会显示回切按钮,可以执行回切

DBA执行回切,系统会创建回切任务,并可以查看回切的具体信息

京东MySQL数据库主从切换自动化

4.2活切(一般运维停机切换)
4.2.1 批量创建任务:

输入项目里的任一IP,就可以查出该项目下的所有可用集群,然后勾选想要切换的集群,提交批量创建任务。

创建任务时可选择目标实例是本地,还是异地。然后先对目标实例探活,再根据先物理机后DOCKER,先查连接数少,后查QPS负载低的原则推荐实例。如果有异常会提示。

另外可选择切换后新主库是否为read only

4.2.2任务切换

点击切换,会批量切换本次任务,并可以进入子任务查看具体切换的每个步骤,及MHA执行的每个步骤,切换完成,会等待2分钟去校验域名是否真实切换。

切换后会有前后架构的对比。

可以kill旧主库的所有应用链接。

4.2.3 举例

有个Mysql_test项目下有2个集群,如下

集群1

京东MySQL数据库主从切换自动化

集群2

京东MySQL数据库主从切换自动化

1. 批量创建任务

选择原则根据先本地后异地,先物理机后Docker,先连接数后QPS原则,

10.66.66.66:3366选择目标主库为:10.88.88.89:3366

京东MySQL数据库主从切换自动化

10.66.55.55:3366选择目标主库为:10.88.99.91:3366

京东MySQL数据库主从切换自动化

2. 批量执行切换

京东MySQL数据库主从切换自动化

切换子任务详细信息,可查看到每个子任务的切换结果及执行步骤,前后架构

京东MySQL数据库主从切换自动化

京东MySQL数据库主从切换自动化

5. 总结

该系统不管是死切,还是活切,都已服务化,接口化,都只需最多2步(创建任务,执行切换)就可完成切换,也可以完全自动化切换(需要业务方同意,因为有些业务数据库故障后需要业务方确认切换),也可以把活切做成流程化交给业务方自助切换。目前该系统已经运行良好,极大的节省了DBA时间,更好地做到数据库的高可用,保证持续提供服务,简化DBA操作,节省数据库故障切换的时间,为京东的数据库保驾护航。

京东MySQL数据库主从切换自动化

您可能感兴趣的文档:

--结束END--

本文标题: 京东MySQL数据库主从切换自动化

本文链接: https://www.lsjlt.com/news/37729.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL5.7一主两从MHA自动切换
    这篇文章主要讲解了“MySQL5.7一主两从MHA自动切换”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL5.7一主两从MHA自动切换”吧!数据库架...
    99+
    2024-04-02
  • Mysql 数据库 主从数据库 (主从)(主主)
    一、什么是主从数据库 主从数据库就是把数据库架构分为主数据库和从数据库。从数据库是主数据库的备份,以提高数据的安全性,不至于一个数据库崩掉而导致整个项目也运行不起来。可以有效的防止财产的损失。一般从库只做查询操作,而主库则做更改操作,也就是...
    99+
    2023-09-28
    数据库 mysql 服务器
  • MySQL数据库主从服务器如何部署和切换文档
    本篇内容介绍了“MySQL数据库主从服务器如何部署和切换文档”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
    99+
    2024-04-02
  • mysql主备自动切换怎么实现
    要实现MySQL主备自动切换,可以使用MySQL Replication和MySQL Cluster来实现高可用性。以下是一种实现方...
    99+
    2024-04-09
    mysql
  • mysql主备自动切换如何设置
    要设置MySQL主备自动切换,可以使用MySQL Replication来实现主备复制和故障切换。以下是设置主备自动切换的步骤: ...
    99+
    2024-04-09
    mysql
  • MySQL数据库中怎么实现主备切换
    MySQL数据库中怎么实现主备切换,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、查看主库状态show processlist...
    99+
    2024-04-02
  • PHP实现Oracle主从复制自动切换的方法
    随着互联网技术的不断发展,对于Web应用程序的高可用性和负载均衡性的要求越来越高。其中,数据库是Web应用程序中的重要部分,也是其中最容易成为瓶颈的部分。为了解决数据库的高可用性问题,主从复制已经成为了一种比较常见的解决方案。而PHP是We...
    99+
    2023-05-15
    PHP Oracle主从复制 自动切换
  • PHP实现Redis主从复制自动切换的方法
    Redis是一款非常流行的键值对存储数据库,在现代Web应用中扮演着至关重要的角色。为了保证Redis的高可用性和稳定性,通常需要使用主从复制的技术。同时,由于主节点故障时需要自动切换到备用节点,使得复制集群具有自我修复的能力。下面介绍PH...
    99+
    2023-05-16
    PHP Redis 主从复制
  • PHP实现数据库主从复制故障切换的方法
    随着互联网的快速发展,数据库作为后台数据存储的重要组成部分,对于网站的高可用性和性能优化至关重要。其中,主从复制是一个常用的数据库高可用性解决方案,可以在不影响服务的情况下提高系统的稳定性和可用性。本文主要介绍如何使用PHP实现主从复制及故...
    99+
    2023-05-15
    PHP 数据库主从复制 故障切换
  • Mysql主从数据库搭建(一主两从)
    目录 1、服务器规划 2、主从同步流程 3、主从搭建 3.1、master节点上配置文件修改 3.2、master节点创建同步用户和权限 3.3、slave1和slave2节点配置文件修改 3.4、slave1和slave2节点执行同步任...
    99+
    2023-08-31
    数据库 mysql 服务器
  • python自动化管理mysql主从同步
    mysql多实例1.my.cnf通过定义mysqldconfig类   mysqld_vars = {}  从里面获得很多配置文件相关参数写入字典mysql.py2.init DB初始化数据库3.修改权限4.rc脚本启动5.check 检查...
    99+
    2023-01-31
    主从 python mysql
  • Java自动化测试中多数据源如何切换
    这篇文章主要介绍了Java自动化测试中多数据源如何切换,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一. 用外部文件做数据驱动的基本写法1.1 我们在做数据驱动时,把数据存储...
    99+
    2023-05-31
    java
  • redis主从切换数据丢失如何找回
    当Redis主从切换过程中出现数据丢失的情况时,可以通过以下方法找回数据: 首先,检查Redis主从同步的状态,确保主从之间的同步...
    99+
    2024-04-09
    redis
  • 怎么使用PHP实现数据库主从复制故障切换
    今天小编给大家分享一下怎么使用PHP实现数据库主从复制故障切换的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、主从复制的基...
    99+
    2023-07-06
  • 快速实现数据库的转换,如从Mysql切换到Postgresql【含gif】
    快速实现数据库的转换,以数据库从从Mysql切换到Postgresql为例 因为项目的需要,需要将使用的数据库A从Mysql切换到Postgresql并且合并到同一个数据库B中。 使用Navicat 快速将Mysql表快速转为Postgre...
    99+
    2023-08-17
    数据库 postgresql mysql
  • 监控mysql数据库主从状态
    python版本2.6.6#!/usr/bin/pythonimport MySQLdbdef check_mysql():    status = True &nb...
    99+
    2024-04-02
  • SpringBoot自定义+动态切换数据源教程
    目录1、添加maven依赖2、配置application.yml3、配置动态数据源4、配置数据源操作Holder5、读取自定义数据源,并配置6、动态切换关键——AOP进行切换7、使用...
    99+
    2024-04-02
  • Mysql数据库的主从同步配置
    目录Mysql主从同步配置1、安装两个 mysql 2、编写mysql配置文件3、初始化数据4、其他mysql 相关命令Mysql主从同步配置 配置准备: 需要两个数据库...
    99+
    2024-04-02
  • 【数据库】MySQL的主从复制模式
    MySQL的主从复制模式包括异步复制,全同步复制,半同步复制。MySQL默认为异步模式。MySQL5.7引入了一种新的半同步方案,并且在5.7引入了一个新的参数,rpl_semi_sync_master_wait_point,这个参数有...
    99+
    2023-09-17
    数据库 mysql java
  • MySQL数据库——MySQL AUTO_INCREMENT:主键自增长
    在 MySQL 中,当主键定义为自增长后,这个主键的值就不再需要用户输入数据了,而由数据库系统根据定义自动赋值。每增加一条记录,主键会自动以相同的步长进行增长。 通过给字段添加 AUTO_INCREMENT 属性来实现主键自增长。语法格式如...
    99+
    2023-09-02
    数据库 mysql sql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作