MHA高可用

技术MHA高可用 MHA高可用目录今日内容概述今日内容详细1.MHA高可用概述2.MHA的工作原理MHA的组成MHA自动故障切换的步骤3.MHA的优点总结4.GTID主从复制什么是GTID主从复制GTI

MHA高可用性。

今天内容概述1。MHA 2的高可用性概述。MHA的工作原理3。MHA优势概述4。GTID的主从复制GTID的主从复制原理是什么1)GTID的生命周期2)图解5。GTID 6的优缺点。GTID主从复制的部署环境。准备主库配置从库配置创建mha管理用户设置从库读取关闭MySQL自动清除relaylog 7的功能。MHA部署配置安全登录(所有主机相互交互)安装依赖包(所有机器执行)然后转到管理器主机安装管理器包配置MHA管理器修改配置并检测MHA配置状态启动MHA

今日内容概述

1.1概述。MHA高可用性。

2.2.MHA的工作原理

3.3.MHA优势总结

4.4.GTID的主从复制

5.GTID主从复制的优缺点

6.GTID主从复制部署。

7.MHA部署。

今日内容详细

1.MHA高可用概述

# mha简介

MHA(Master High Availability,MHA)是一个成熟的开源MySQL高可用性程序,由日本yoshinorim(以前为DeNA工作,现在为FaceBook工作)开发。它为MySQL主从复制架构提供了自动化的主故障转移。当MHA监视主节点的故障时,它将把具有最新数据的从节点提升到新的主节点。在此期间,MHA将通过从其他从节点获取额外的信息来避免一致性问题,从而最大程度上保证数据的一致性,从而实现真正意义上的高可用性,整个故障转移过程对应用程序完全透明。最值得称赞的一点是,这种自动故障转移操作可以由MHA在10~30秒内完成。#但是对于数据库来说还是太长了。

此外,MHA还提供主节点在线切换功能,即根据需要切换主/从节点,约0.5-2秒即可完成。

目前MHA主要支持一主多从的架构。要构建MHA,复制群集中必须至少有三个数据库服务器,例如一个主服务器和两个从服务器。因为至少需要三台服务器,为了机器成本,淘宝也在此基础上进行了改造。目前,淘宝的TMHA已经支持一主一从。

2.MHA的工作原理

MHA的组成

MHA由节点和管理器组成。

1.MHA节点(数据节点:

相当于监控客户端,所有机器都需要部署节点。

2.MHA经理(管理节点)。

管理器相当于服务器。MHA管理器将定期探测群集中的主节点。当主设备出现故障时,它可以自动将最新数据的从设备升级到新的主设备,然后将所有其他从设备重定向到新的主设备(如果恢复了原来的主库,则只能用作从库)。

一般部署在独立的机器上管理多个主/从集群(组),每个主/从集群称为一个应用,用于管理和协调整个集群。

管理者应尽可能避免在主库上部署,否则,当主库挂起时,所有库都会被挂起。不仅主库完成了,负责自动迁移的Manager也完成了,没有人负责自动故障迁移,导致架构不可用。

可以考虑在从机上部署。这时,主人挂断了,但只有一个奴隶挂断了。管理器需要注意的一点是,如果管理器部署在从机上,则从机不能升级为主库。

#从下图中我们可以看到,需要ssh来实现每个复制组和Manager之间的无密码互连。只有这样,当主设备出现故障时,管理器才能顺利连接,实现主从切换。

MHA自动故障切换的步骤

1.1。管理器将每3秒探测一次MASTER主库#以检查主库是否存在。

2.如果管理器检测到主主库出现故障并且无法访问,管理器将执行以下操作:

从其他节点发起ssh连接,检查主库是否可以SSH。

从其他节点发起mysql连接,检查MASTER库是否可以登录。

3.如果所有Node ssh连接和mysql主库连接都失败,请启动故障转移。

总而言之,接下来的步骤是:

1.)从库中查找最新数据(通过比较re。

lay-log,查看show slave status即可)
2.)将最新的从库上的新数据同步到其他从库
3.)提升一个从库为主库(一般情况提升数据最新的,二般情况提升我们指定的从库为主库)
4.)通过原来主库的binlog补全新的主库数据
5.)其他从库以新的主库为主做主从复制

3.MHA的优点总结

1. 自动的故障检测与转移,通常在10-30秒以内
2. MHA还提供在线主库切换的功能,能够安全地切换当前运行的主库到一个新的主库中(通过将从库提升为主库),大概0.5-2秒内即可完成。
3. 很好地解决了主库崩溃数据的一致性问题。
4. 不需要对当前的mysql环境做重大修改。
5. 不需要在现有的复制框架中添加额外的服务器,仅需要一个manager节点,而一个Manager能管理多套复制,所以能大大地节约服务器的数量。
6. 性能优秀,可以工作在半同步和异步复制框架,支持gtid,当监控mysql状态时,仅需要每隔N秒向master发送ping包(默认3秒),所以对性能无影响。你可以理解为MHA的性能和简单的主从复制框架性能一样。
7. 只要replication支持的存储引擎都支持MHA,不会局限于innodb。
8. 对于一般的keepalived高可用,当vip在一台机器上的时候,另一台机器是闲置的,而MHA中并没有闲置的主机。

4.GTID主从复制

什么是GTID主从复制

从MySQL 5.6.2 开始新增了一种基于 GTID 的复制方式,用以替代以前传统的复制方式,到MySQL5.6.10后逐渐完善。通过 GTID 保证了每个在主库上提交的事务在集群中有一个唯一的ID。这种方式强化了数据库的主备一致性,故障恢复以及容错能力.

在MHA自动故障切换过程中,MHA试图从宕机的主服务器上保存二进制日志,最大程度的保证数据的不丢失,但这并不总是可行的。例如,如果主服务器硬件故障或无法通过ssh访问,MHA没法保存二进制日志,只进行故障转移而丢失了最新的数据。使用自MySQL 5.5开始引入的半同步复制,可以大大降低数据丢失的风险。

MHA可以与半同步复制结合起来。如果只有一个slave已经收到了最新的二进制日志,MHA可以将最新的二进制日志应用于其他所有的slave服务器上,因此可以保证所有节点的数据一致性,或者采用GTID。

要想在分布式集群环境中不丢失事务,就必须为每个事务定制一个全局唯一的ID号,并且该ID是趋势递增的,以此我们便可以方便地顺序读取、不丢事务,其实GTID就是一种很好的分布式ID实践方案,它满足分布ID的两个基本要求:
# 全局唯一性
# 趋势递增
  
GTID (Global Transaction ID全局事务ID)是如何做到全局唯一且趋势递增的呢,它是由UUID+TID两部分组成。
# UUID是数据库实例的标识符
# TID表示事务提交的数量,会随着事务的提交递增
因此它与主库上提交的每个事务相关联,GTID不仅对其发起的服务器是唯一的,而且在给定复制设置中的所有服务器都是唯一的,即所有的事务和所有的GTID都是1对1的映射。
当在主库上提交事务或者被从库应用时,可以定位和追踪每一个事务,对DBA来说意义就很大了,我们可以适当的解放出来,不用手工去可以找偏移量的值了,而是通过CHANGE MASTER TO MASTER_HOST='xxx', MASTER_AUTO_POSITION=1的即可方便的搭建从库,在故障修复中也可以采用MASTER_AUTO_POSITION= 'X' 的方式。
5.7版本GTID做了增强,不手工开启也自动维护匿名的GTID信息。

GTID主从的原理

1)一个GTID的生命周期

1.事务在主库上执行并提交给事务分配一个gtid(由主库的uuid和该服务器上未使用的最小事务序列号),该GTID被写入到binlog中。
 
2.备库读取relaylog中的gtid,并设置session级别的gtid_next的值,以告诉备库下一个事务必须使用这个值
 
3.备库检查该gtid是否已经被其使用并记录到他自己的binlog中。slave需要担保之前的事务没有使用这个gtid,也要担保此时已分读取gtid,但未提交的事务也不恩呢过使用这个gtid.
 
4.由于gtid_next非空,slave不会去生成一个新的gtid,而是使用从主库获得的gtid。这可以保证在一个复制拓扑中的同一个事务gtid不变。由于GTID在全局的唯一性,通过GTID,我们可以在自动切换时对一些复杂的复制拓扑很方便的提升新主库及新备库,例如通过指向特定的GTID来确定新备库复制坐标

2)图解

同样的GTID不能被执行两次,如果有同样的GTID,会自动被skip掉
salve1:将自己的UUID1:1发送给master,然后接收到了UUID1:2,UUID1:3 event
salve2:将自己的UUID1:1,UUID1:2发送给master,然后接收到了UUID1:3event

5.GTID主从复制的优缺点

GTID的优点

一个事务对应一个唯一ID,一个GTID在一个服务器上只会执行一次。
GTID是用来代替传统复制的方法,GTID复制与普通复制模式的最大不同就是不需要指定二进制文件名和位置。
减少手工干预和降低服务故障时间,当主机挂了之后通过软件从众多的备机中提升一台备机为主机。

GTID的缺点

不支持非事务引擎。
不支持create table ... select 语句复制(主库直接报错);(原理: 会生成两个sql, 一个是DDL创建表SQL, 一个是insert into 插入数据的sql; 由于DDL会导致自动提交, 所以这个sql至少需要两个GTID, 但是GTID模式下, 只能给这个sql生成一个GTID)。
不允许一个SQL同时更新一个事务引擎表和非事务引擎表。
在一个复制组中,必须要求统一开启GTID或者是关闭GTID。
开启GTID需要重启 (mysql5.7除外)。
开启GTID后,就不再使用原来的传统复制方式。
对于create temporary table(创建临时表) 和 drop temporary table (删除临时表)语句不支持。
不支持sql_slave_skip_counter(跳过错误)。

6.GTID主从复制部署

环境准备

机器名称 IP地址 角色 备注
manager 172.16.16.50 Manager控制器 用于监控管理
master 172.16.16.52 主数据库服务器 开启binlog、relay-log,关闭relay_log_purge
slave1 172.16.16.53 从1数据库服务器 开启binlog、relay-log,关闭relay_log_purge、设置read_only=1
slave2 172.16.16.54 从2数据库服务器 开启binlog、relay-log,关闭relay_log_purge、设置read_only=1
其中master对外提供写服务,备选master提供读服务,salve页提供相关的读服务,一旦master宕机,将会把备选master提升为新master,slave指向新的master,manager作为管理服务器。

主库配置

1.准备一台纯净的linux主机,二进制安装MySQL5.7,初始化,配置环境变量,配置systemctl管理,配置好配置文件后重启
[root@mysql_master mysql_data]# cat /etc/my.cnf
[mysqld]
basedir=/usr/local/mysql
datadir=/mysql_data
port=3306
socket=/usr/local/mysql/mysql.sock
character-set-server=utf8mb4
log-error=/var/log/mysqld.log
pid-file=/tmp/mysqld.pid
server-id = 1                                
binlog_format='row'                          
log-bin = /var/lib/mysql/mybinlog
skip-name-resolve
gtid-mode=on
enforce-gtid-consistency=true
log-slave-updates=1
relay_log_purge=0
sync_binlog=1            
expire_logs_days = 7                        
max_binlog_size = 100M
binlog_cache_size=4m
max_binlog_cache_size=512m                        
binlog_rows_query_log_events=on          
			
[mysql]
socket=/usr/local/mysql/mysql.sock
[client]
socket=/usr/local/mysql/mysql.sock
systemctl restart mysqld
2.增加主从复制的用户
GRANT REPLICATION SLAVE ON *.* TO 'jerry'@'%' IDENTIFIED BY '123';
flush privileges;

从库配置

1.准备一台纯净的linux主机,二进制安装MySQL5.7,初始化,配置环境变量,配置systemctl管理,配置好配置文件后重启
[root@mysql_salve01 ~]# cat /etc/my.cnf 
[mysqld]
basedir=/usr/local/mysql
datadir=/mysql_data
port=3306
socket=/usr/local/mysql/mysql.sock
character-set-server=utf8mb4
log-error=/var/log/mysqld.log
pid-file=/tmp/mysqld.pid
# 中继日志
relay-log=mysql-relay-bin
replicate-wild-ignore-table=test.%
replicate-wild-ignore-table=information_schema.%
# 节点ID,确保唯一
server-id=2
binlog_format=row
log-bin=mysql-bin
skip-name-resolve
gtid-mode=on
enforce-gtid-consistency=true
log-slave-updates=1
relay_log_purge=0
sync_binlog=1
expire_logs_days=7
#binlog每个日志文件大小
max_binlog_size=100m
#binlog缓存大小
binlog_cache_size=4m 
#最大binlog缓存大小
max_binlog_cache_size=512m
			
[mysql]
socket=/usr/local/mysql/mysql.sock
[client]
socket=/usr/local/mysql/mysql.sock
从库执行
mysql change master to 
    -     master_host='172.16.1.53',
    -     master_user='jerry',
    -     master_password='123',
    -     MASTER_AUTO_POSITION=1;
Query OK, 0 rows affected, 2 warnings (0.00 sec)
mysql start slave;
Query OK, 0 rows affected (0.00 sec)
mysql show slave status\G
# 结果如下图

创建MHA管理用户

在主库创建
mysql grant all on *.* to 'mhaadmin'@'%' identified by '123';
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql flush privileges;
Query OK, 0 rows affected (0.00 sec)
# 因为已经成功部署GTID主从复制,所以从库也有这个用户

设置从库可读

# 在从库上进行操作
# 设置只读,不要添加配置文件,因为从库以后可能变成主库
mysql set global read_only=1;
Query OK, 0 rows affected (0.00 sec)
mysql show global variables like "%read_only%";
+-----------------------+-------+
| Variable_name         | Value |
+-----------------------+-------+
| innodb_read_only      | OFF   |
| read_only             | ON    |
| super_read_only       | OFF   |
| transaction_read_only | OFF   |
| tx_read_only          | OFF   |
+-----------------------+-------+
5 rows in set (0.00 sec)

关闭MySQL自动清除relaylog的功能

# 关闭MySQL自动清除中继日志功能
这一步已经在之前的配置文件中配置好了
[mysqld]
#禁用自动删除relay log永久生效
relay_log_purge = 0

7.MHA部署

配置免密登录(所有主机之间互做)

# 创建秘钥对
# 正常创建 ssh-keygen 需要交互,按回车,可以用一下方法跳过交互
ssh-keygen -t dsa -P '' -f ~/.ssh/id_dsa  /dev/null
# 发送公钥,包括自己
for i in 50 52 53 54;do ssh-copy-id -i ~/.ssh/id_dsa.pub root@192.168.174.${i};done

安装依赖包(所有机器都执行)

# 安装yum源
wget http://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
rpm -ivh epel-release-latest-7.noarch.rpm
 
# 安装MHA依赖的perl包
yum install -y perl-DBD-MySQL perl-Config-Tiny perl-Log-Dispatch perl-Parallel-ForkManager
wget https://qiniu.wsfnk.com/mha4mysql-node-0.58-0.el7.centos.noarch.rpm --no-check-certificate
rpm -ivh mha4mysql-node-0.58-0.el7.centos.noarch.rpm

然后再去manager主机安装manager包

wget https://qiniu.wsfnk.com/mha4mysql-manager-0.58-0.el7.centos.noarch.rpm --no-check-certificate
rpm -ivh mha4mysql-manager-0.58-0.el7.centos.noarch.rpm

配置MHA Manager

# 创建工作目录
mkdir -p /service/mha/
mkdir /service/mha/app1

修改配置

vim /service/mha/app1.cnf
[server default]            
#日志存放路径
manager_log=/service/mha/manager.log
#定义工作目录位置
manager_workdir=/service/mha/app1
#binlog存放目录(如果三台数据库机器部署的路径不一样,可以将配置写到相应的server下面)
#master_binlog_dir=/usr/local/mysql/data
 
#设置ssh的登录用户名
ssh_user=root
#如果端口修改不是22的话,需要加参数,不建议改ssh端口
#否则后续如负责VIP漂移的perl脚本也都得改,很麻烦
ssh_port=22
 
#管理用户
user=mhaadmin
password=123
 
#复制用户
repl_user=jerry
repl_password=123
 
#检测主库心跳的间隔时间
ping_interval=1
 
[server1]
# 指定自己的binlog日志存放目录
master_binlog_dir=/mysql_data
hostname=172.16.1.52
port=3306
 
[server2]
#暂时注释掉,先不使用
#candidate_master=1
#check_repl_delay=0
master_binlog_dir=/mysql_data
hostname=172.16.1.53
port=3306
 
[server3]
master_binlog_dir=/mysql_data
hostname=172.16.1.54
port=3306
 
# 1、设置了以下两个参数,则该从库成为候选主库,优先级最高
# 不管怎样都切到优先级高的主机,一般在主机性能差异的时候用         
candidate_master=1
# 不管优先级高的备选库,数据延时多久都要往那切
check_repl_delay=0
 
# 2、上述两个参数详解如下:
# 设置参数candidate_master=1后,则判断该主机为为候选master,发生主从切换以后将会将此从库提升为主库,即使这个主库不是集群中事件最新的slave。
 
# 默认情况下如果一个slave落后master 100M的relay logs的话,MHA将不会选择该slave作为一个新的master,因为对于这个slave的恢复需要花费很长时间,通过设置check_repl_delay=0,MHA触发切换在选择一个新的master的时候将会忽略复制延时,这个参数对于设置了candidate_master=1的主机非常有用,因为这个候选主在切换的过程中一定是新的master
 
# 3、应该为什么节点设置这俩参数,从而把该节点的优先级调高
# (1)、多地多中心,设置本地节点为高权重
# (2)、在有半同步复制的环境中,设置半同步复制节点为高权重
# (3)、你觉着哪个机器适合做主节点,配置较高的 、性能较好的

检测mha配置状态

# 测试免密连接
1.使用mha命令检测ssh免密登录
masterha_check_ssh --conf=/service/mha/app1.cnf
    ALL SSH ... successfilly 表示ok了
 
2.使用mha命令检测主从状态
masterha_check_repl --conf=/service/mha/app1.cnf
    ... Health is OK
 
# 如果出现问题,可能是反向解析问题,配置文件加上
    skip-name-resolve
# 还有可能是主从状态,mha用户密码的情况

启动MHA

nohup masterha_manager --conf=/service/mha/app1.cnf --remove_dead_master_conf --ignore_last_failover  /dev/null  /service/mha/manager.log 21 
 
命令参数:
--remove_dead_master_conf       该参数代表当发生主从切换后,宕机库的配置信息将会从配置文件中移除。
--manger_log                    日志存放位置
--ignore_last_failover          在缺省情况下,如果MHA检测到连续发生宕机,且两次宕机间隔不足8小时的话,则不会进行Failover,之所以这样限制是为了避免ping-pong效应。该参数代表忽略上次MHA触发切换产生的文件,默认情况下,MHA发生切换后会在日志目录,也就是上面设置的manager_workdir目录中产生app1.failover.complete文件,下次再次切换的时候如果发现该目录下存在该文件将不允许触发切换,除非在第一次切换后收到删除该文件,为了方便,这里设置为--ignore_last_failover。
 
# MHA的安全机制:
    1.完成一次切换后,会生成一个锁文件在工作目录中
    2.下次切换之前,会检测锁文件是否存在
    3.如果锁文件存在,8个小时之内不允许第二次切换 

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/37477.html

(0)

相关推荐

  • OpenEuler基础实验

    技术OpenEuler基础实验 OpenEuler基础实验OpenEuler基础实验
    20191331 lyx
    基于 鲲鹏--OpenEuelr 20.03 64bit--ARM (华为云服务器)
    实验

    礼包 2021年11月1日
  • brew mysql无法连接问题怎么解决

    技术brew mysql无法连接问题怎么解决本篇内容介绍了“brew mysql无法连接问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大

    攻略 2021年12月4日
  • oracle归档日志流式分析(oracle执行语句分析)

    技术Oracle查询脚本的示例分析这篇文章将为大家详细讲解有关Oracle查询脚本的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 --查询回滚段信

    攻略 2021年12月20日
  • 一个马的车标是什么车,“一匹马”的车标是什么车

    技术一个马的车标是什么车,“一匹马”的车标是什么车标志中有马的车的品牌有一个马的车标是什么车:法拉利、福特野马、保时捷等。站起来的马是法拉利。奔跑中的是福特野马,带盾牌的马是保时捷。
    法拉利的简介
    法拉利是一家意大利汽车

    生活 2021年10月20日
  • 红领巾心向党征文,求一个红领巾心向党的童谣

    技术红领巾心向党征文,求一个红领巾心向党的童谣红领巾心向党 童谣 自己写的,不得抄袭,发到我邮箱 不发到邮箱不给分 :我爱红领巾 少先队员真光荣, 庄严宣誓记心中红领巾心向党征文。 爱国爱校爱班级, 认真学习要用功。 文

    生活 2021年10月29日
  • redis的sentinel配置文件(redis 的sentinel原理)

    技术Redis中的Sentinel机制怎么用这篇文章将为大家详细讲解有关Redis中的Sentinel机制怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 概述Redis-Se

    攻略 2021年12月15日