MySQL半同步复制原理配置与介绍详解

环境介绍:

Ubuntu Server 16.04.2+MySQL 5.7.17 Community Server (GPL)

MySQL安装

通过APT的方式安装,官方指导文档地址: 
https://dev.mysql.com/downloads/repo/apt/

1、下载mysql-apt-config_0.8.3-1_all.deb

2、安装deb

A Quick Guide to Using the MySQL APT Repository: 
https://dev.mysql.com/doc/mysql-apt-repo-quick-guide/en/

?


1

>sudo dpkg -i mysql-apt-config_0.8.3-1_all.deb

3、更新源

?


1

>sudo apt-get update

4、安装MySQL

?


1

>sudo apt-get install mysql-server

5、根据提示选择安装和设置密码。

另外,还需要对其进行设置,绑定的IP和打开防火墙的3306端口,这里主要是学习MySQL半同步复制,对MySQL的安装不做多解释,如果疑问欢迎留言。

MySQL半同步复制介绍

(1)默认情况下,MySQL的复制功能是异步的,异步复制可以提供最佳的性能, 主库把binlog日志发送给从库,这一动作就结束了,并不会验证从库是否接收完毕,这一过程,也就意味着有可能出现当主服务器或从服务器端发生故障的时候,有可能从服务器没有接收到主服务器发送过来的binlog日志,这就会造成主服务器和从服务器的数据不一致,甚至在恢复时造成数据的丢失。

注意:

半同步复制模式必须在主服务器和从服务器端同时开启,否则主服务器默认使用异步复制模式。

(2)异步复制案例:

MySQL5.6 数据库主从(Master/Slave)同步安装与配置详解

(3)为了解决上述可能发生的错误,MySQL 5.5 引入了一种半同步复制模式。该模式可以确保从服务器接收完主服务器发送的binlog日志文件并写入到自己的中继日志relay log里,然后会给主服务器一个反馈,告诉主服务器已经接收完毕,这时主服务线程才返回给当前session告知操作完成。

(4)当出现超时情况是,主服务器会暂时切换到异步复制模式,直到至少有一个从服务器从及时收到信息为止。

(5)中继日志的自我修复:

从MySQL 5.5.X 版本开始,增加了relay_log_recovery参数,这个参数的作用是:当slave从库宕机后,假如relay.log损坏了,导致一部分中继日志没有处理,则自动放弃所有未执行的relay-log,并且重新从master上获取日志,这样就保证了relay-log的完整性。默认情况下该功能是关闭的,将relay_log_recovery的值设置为1时,可在slave从库上开启该功能,建议开启。

(6)半同步复制与异步复制的切换:

半同步复制的工作原理就是当slave从库IO_Thread线程将binlog日志接收完毕之后,要给master主库一个确认,如果rpl_semi_sync_master_timeout=10000 (10秒)超过10秒未收到slave从库的接受确认信号,那么就会自动切换为传统的异步复制模式。

MySQL半同步复制配置

首先,需要安装两个MySQL,这里是:

  • Master:192.168.1.227
  • Slave:192.168.1.224

原始数据库的模样如下:

一、Master配置

(1)在Master数据库安装半同步复制插件:

?


1

mysql>INSTALL PLUGIN rpl_semi_sync_master SONAME ‘semisync_master.so‘;

(2)设置Master上开启半同步复制:

?


1

mysql>SET GLOBAL rpl_semi_sync_master_enabled = 1;

(3)修改mysqld.cnf 配置文件:

上图指出了MySQL配置的文件路径。

?


1

2

3

4

5

6

7

[mysqld]

log-bin=mysql-bin

server_id = 10086

server_id_bits = 33

rpl_semi_sync_master_enabled=1

rpl_semi_sync_master_timeout=1000

(4)修改MySQL server-uuid配置文件:

?


1

2

[email protected]:/var/lib/mysql# pwd

/var/lib/mysql

修改 auto.cnf文件,server-uuid的值格式固定,为了和Slave的区别开

?


1

2

[auto]

server-uuid=8d90feb7-1a88-11e7-9d11-000c298a546f

(5)查看配置是否成功:

?


1

mysql>SELECT PLUGIN_NAME, PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE PLUGIN_NAME LIKE ‘%semi%‘;

(6)参数说明:

1、rpl_semi_sync_master_enabled = 1,表示在master上已经开启了半同步复制模式;

2、rpl_semi_sync_master_timeout = 10000,表示如果主库在某次事务中的等待时间超过10000毫秒,则降级为异步复制模式,不在等待slave从库。如果主库再次探测到slave从恢复了,则会自动切换回半同步复制模式;

3、rpl_semi_sync_master_wait_no_slave ,表示是否允许master每个事务提交后都要等待slave的接收确认信号。默认为ON,即每一个事务都会等待。如果为OFF,则slave追赶上之后,也不会开启半同步复制模式,需要手工开启;

4、rpl_semi_sync_master_trace_level = 32,指用于开启半同步复制模式时的调试级别,默认为32。

可以看出,在配置Master的时候,只设置了1,其他的都采取的默认设置。

二、Slave配置

(1)在Slave数据库安装半同步复制插件:

?


1

mysql>INSTALL PLUGIN rpl_semi_sync_slave SONAME ‘semisync_slave.so‘;

(2)设置Slave上开启半同步复制:

?


1

mysql>SET GLOBAL rpl_semi_sync_slave_enabled = 1;

(3)修改mysqld.cnf 配置文件:

?


1

2

3

4

5

6

[mysqld]

log-bin=mysql-bin

server_id=10089

server_id_bits = 32

rpl_semi_sync_slave_enabled = 1

(4)修改MySQL server-uuid配置文件:

?


1

2

[email protected]:/var/lib/mysql# pwd

/var/lib/mysql

修改 auto.cnf文件,server-uuid的值格式固定,为了和Slave的区别开

?


1

2

[auto]

server-uuid=8d90feb7-1a88-11e7-9d11-000c298a123f

确保和Master的server-uuid不一样!

(5)查看配置是否成功:

?


1

mysql>SELECT PLUGIN_NAME, PLUGIN_STATUS FROM INFORMATION_SCHEMA.PLUGINS WHERE PLUGIN_NAME LIKE ‘%semi%‘;

(6)参数说明:

1、rpl_semi_sync_slave_enabled = 1,表示在slave上已经开启了半同步复制模式;

2、rpl_semi_sync_slave_trace_level = 32,指用于开启半同步复制模式时的调试级别,默认为32。

三、为Slave指定Master

(1)命令行模式下重启Master

?


1

[email protected]:~# service mysql restart

(2)命令行模式下重启Slave

?


1

[email protected]:~# service mysql restart

(3)查看Master状态:

?


1

2

3

4

5

6

7

8

9

10

mysql> show master status\G;

*************************** 1. row ***************************

       File: mysql-bin.000004

     Position: 154

   Binlog_Do_DB:

 Binlog_Ignore_DB:

Executed_Gtid_Set:

1 row in set (0.02 sec)

mysql>

注意:

?


1

2

File: mysql-bin.000004

Position: 154

很重要,后边需要使用!

(4)为Slave指定Master:

1、首先关闭Slave的半同步复制

?


1

2

mysql> stop slave;

Query OK, 0 rows affected (0.01 sec)

2、为Slave指定Master

?


1

2

3

mysql>change master to master_host=‘192.168.1.227‘,master_user=‘root‘,master_password=‘123456‘,master_log_file=‘mysql-bin.000004‘, master_log_pos=154;

Query OK, 0 rows affected, 2 warnings (0.02 sec)

其中:

?


1

2

3

4

5

master_host=‘192.168.1.227‘,Master主库IP地址

master_user=‘root‘,Master主库数据库账户

master_password=‘123456‘,Master主库数据库root用户密码

master_log_file=‘mysql-bin.000004‘, Master主库binlog文件

master_log_pos=154,Master主库binlog文件position

注意:

在MySQL 5.6版本以后,在进行主从复制的时候可以使用GTID的方式,无需再找binglog和pos点,只需要知道主服务器的IP、端口、账户、密码就可以实现自动找点同步,开启GTID功能的时候就不用再使用binlog和pos了。详细信息,请查阅相关资料进行学习。

3、开启Slave的半同步复制

?


1

2

mysql> start slave;

Query OK, 0 rows affected (0.01 sec)

四、测试半同步复制是否成功

五、如何优雅的关闭Slave同步信息

在某些时候,一台服务器不再用来作为Slave,那么我们就需要清楚他的同步信息,一般会使用:

?


1

2

mysql> stop slave #先关闭

mysql> reset slave #清楚Slave同步信息

但是,这样再通过show master status\G显示的时候:

?


1

mysql> show master status\G;

还是会出现同步的信息,这是因为执行了 reset slave 只是把 master.info 和 relay-log.info 文件删除了,但同步信息还在,如果有人在执行start slave命令开启了同步功能,结果就会又从头开始同步了,有可能还会造成数据的丢失。

如何让其清除的更干净哪?请使用下边的命令:

?


1

2

mysql> stop slave #先关闭

mysql> reset slave all#清楚Slave同步信息

再次执行show master status\G就不会再有任何信息了。

六、部分异常场景模拟

(1)半同步复制与异步复制的切换:

上述已经介绍了为什么会出现半同步复制到异步复制的切换,那么现在模拟一个场景进行演示。

场景如下:

1、关闭slave同步,停止IO接收binlog日志

?


1

mysql> stop slave;

该操作就将IO线程关闭,等待10秒之后,如果master未收到来自slave的确认信息,就会切换到异步复制模式:

上图看到slave已经关闭了半同步复制模式,再次开启:

?


1

mysql> start slave;

此时,已经还原到半同步复制模式了。

(2)同步报错案例演示:

我们,首先从slave库上删除数据库表 ufind,然后到master再次删除该库ufind,该同步就会报错:

Last_Error: Error ‘Can‘t drop database ‘ufind‘; database doesn‘t exist‘ on query. Default database: ‘ufind‘. Query: ‘DROP DATABASE `ufind`‘

此时,查看半同步状态:

是开启的,因此没有将半同步复制模式转化为异步复制模式,可以看出半同步复制模式跟IO_Thread是有直接关系的,但跟SQL_THREAD没有关系。

也就是说,slave从库接收完二进制日志后给master主库一个确认,但是他不会管relay-log中继日志是否执行完毕。

六、半同步复制模式性能分析及优缺点

在通常情况下,由于异步复制模式不需要等待从服务器的响应,其速度较半同步复制模式要快,吞吐率要高,在数据进行更新、插入、删除的时候其速度要高于半同步复制模式。但是,半同步复制模式有利于数据的一致性,对于一些数据一致性要求较高的,网络波动较小的可以采用半同步复制模式。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

原文地址:https://www.cnblogs.com/HKROnline-SyncNavigator/p/10971469.html

时间: 2024-10-19 18:49:42

MySQL半同步复制原理配置与介绍详解的相关文章

MySQL 半同步复制模式说明及配置示例 - 运维小结

MySQL主从复制包括异步模式.半同步模式.GTID模式以及多源复制模式,默认是异步模式 (如之前详细介绍的mysql主从复制).所谓异步模式指的是MySQL 主服务器上I/O thread 线程将二进制日志写入binlog文件之后就返回客户端结果,不会考虑二进制日志是否完整传输到从服务器以及是否完整存放到从服务器上的relay日志中,这种模式一旦主服务(器)宕机,数据就可能会发生丢失. 异步模式是一种基于偏移量的主从复制,实现原理是: 主库开启binlog功能并授权从库连接主库,从库通过cha

Mysql半同步复制模式说明 - 运维小结

MySQL主从复制包括异步模式.半同步模式.GTID模式以及多源复制模式,默认是异步模式 (如之前详细介绍的mysql主从复制).所谓异步模式指的是MySQL 主服务器上I/O thread 线程将二进制日志写入binlog文件之后就返回客户端结果,不会考虑二进制日志是否完整传输到从服务器以及是否完整存放到从服务器上的relay日志中,这种模式一旦主服务(器)宕机,数据就可能会发生丢失. 异步模式是一种基于偏移量的主从复制,实现原理是:主库开启binlog功能并授权从库连接主库,从库通过chan

MySQL半同步复制

1.概述 主从复制存在三种类型:异步复制.同步复制以及半同步复制,下面根据手册上解释逐一说明一下. 异步复制: 主库将更新的事件写入binlog,准备好的从库获取这些binlong进行回放.这无法保证所有从库都接到这些事件. ? With asynchronous replication, the master writes events to its binary log and slaves request them when they are ready. There is no guar

mysql 半同步复制

半同步复制 (1).半同步复制原理. 在半同步复制架构中,主机会确保当前的事务至少已经发送到一个备机中(不等待事务重做完成), 才会返回消息到客户端.如果在设置的时间内,事务日志还没传送到备机,那么半同步会变成异步复制. (2).半同步复制的和异步复制的区别: 异步复制:主机不会去检测事务日志是否已经传动到备机,就返回消息到客户端.在高负载的系统中丢失数据的风险比较大. 半同步复制;主机会检测事务日志是否已经至少传送到一个备机中,如果在设置的时间内一直没有传送到一个备机中, 主机不会返回消息到客

mysql半同步复制问题排查

1.问题背景      默认情况下,线上的mysql复制都是异步复制,因此在极端情况下,主备切换时,会有一定的概率备库比主库数据少,因此切换后,我们会通过工具进行回滚回补,确保数据不丢失.半同步复制则要求主库执行每一个事务,都要求至少一个备库成功接收后,才真正执行完成,因此可以保持主备库的强一致性.为了确保主备库数据强一致,减少数据丢失,尝试在生产环境中开启mysql的复制的半同步(semi-sync)特性.实际操作过程中,发现大部分实例半同步都可以正常运行,但有少部分实例始终开不起来(只能以普

mysql半同步复制的实现

mysql半同步复制和异步复制的差别如上述架构图所示:在mysql异步复制的情况下,Mysql Master Server将自己的Binary Log通过复制线程传输出去以后,Mysql Master Sever就自动返回数据给客户端,而不管slave上是否接受到了这个二进制日志.在半同步复制的架构下,当master在将自己binlog发给slave上的时候,要确保slave已经接受到了这个二进制日志以后,才会返回数据给客户端.对比两种架构:异步复制对于用户来说,可以确保得到快速的响应结构,但是

mysql半同步复制实现

mysql半同步复制和异步复制的区别如上述架构图所看到的:在mysql异步复制的情况下.Mysql Master Server将自己的Binary Log通过复制线程传输出去以后,Mysql Master Sever就自己主动返回数据给client.而无论slave上是否接受到了这个二进制日志.在半同步复制的架构下.当master在将自己binlog发给slave上的时候.要确保slave已经接受到了这个二进制日志以后,才会返回数据给client. 对照两种架构:异步复制对于用户来说,能够确保得

MySQL半同步复制实践

半同步复制 MySQL的主从复制在5.5版本以前只支持异步复制,也就是说主库在执行一些事务后,是不管从库备库的进度的,这种方式最大的好处是速度快.效率高:缺点就是在主库宕机后,不能确保从库和主库的数据一致性. 半同步复制的好处就是,主库在每执行一次事务后,会等待备库接受日志后才返回给客户端,如果做的是小事务,两台主机的延迟较小,则可以实现在损失很小的性能的情况下保证零数据丢失. 原理 1)主库每执行一次事务都会先让备库读取日志,确保至少有一台备库上面的数据和自己完整 2)如果在一个timeout

MySQL半同步复制的数据一致性探讨微信后台团队实践【转】

MySQL是一个RDBMS(关系型数据库管理系统),由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品.由于其体积小.速度快.拥有成本低,尤其是开放源码这一特点,广受各大企业欢迎,包括腾讯,阿里,百度,网易,Google,FaceBook等互联网巨头企业. 随着互联网的高速发展,互联网服务可用性变得越发重要,数据容灾也随之成为各企业的关键任务.在数据容灾中,数据库集群如何处理数据一致性也成为了各企业需要解决的问题.特别在一些新兴的金融服务中,MySQL也逐渐成为其核心数据库,如何