mysql5.6半同步主从复制配置

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: mysql5.6半同步主从复制配置 在谈这个特性之前,我们先来看看MySQL的复制架构衍生史。 在2000年,MySQL 3.23.15版本引入了Replication。Replication作为一种准实时同步方式,得到广泛应用。

mysql5.6半同步主从复制配置

在谈这个特性之前,我们先来看看MySQL的复制架构衍生史。

在2000年,MySQL 3.23.15版本引入了Replication。Replication作为一种准实时同步方式,得到广泛应用。这个时候的Replicaton的实现涉及到两个线程,一个在Master,一个在Slave。Slave的I/O和SQL功能是作为一个线程,从Master获取到event后直接apply,没有relay log。这种方式使得读取event的速度会被Slave replay速度拖慢,当主备存在较大延迟时候,会导致大量binary log没有备份到Slave端。

在2002年,MySQL 4.0.2版本将Slave端event读取和执行独立成两个线程(IO线程和SQL线程),同时引入了relay log。IO线程读取event后写入relay log,SQL线程从relay log中读取event然后执行。这样即使SQL线程执行慢,Master的binary log也会尽可能的同步到Slave。当Master宕机,切换到Slave,不会出现大量数据丢失。

在2010年MySQL 5.5版本之前,一直采用的是这种异步复制的方式。主库的事务执行不会管备库的同步进度,如果备库落后,主库不幸crash,那么就会导致数据丢失。于是在MySQL在5.5中就顺其自然地引入了半同步复制,主库在应答客户端提交的事务前需要保证至少一个从库接收并写到relay log中。那么半同步复制是否可以做到不丢失数据呢?下面分析。

在2016年,MySQL在5.7.17中引入了一个全新的技术,称之为InnoDB Group Replication。目前官方MySQL 5.7.17基于Group replication的全同步技术已经问世,全同步技术带来了更多的数据一致性保障。相信是未来同步技术一个重要方向,值得期待。MySQL 5.7 Group Replication

 

半同步机制:

1. 当Master上开启半同步复制的功能时,至少应该有一个Slave开启其功能。此时,一个线程在Master上提交事务将受到阻塞,直到得知一个已开启半同步复制功能的Slave已收到此事务的所有事件,或等待超时。

2. 当Slave主机连接到Master时,能够查看其是否处于半同步复制的机制。

3. 当一个事务的事件都已写入其relay-log中且已刷新到磁盘上,Slave才会告知已收到。

4.  如果等待超时,也就是Master没被告知已收到,此时Master会自动转换为异步复制的机制。当至少一个半同步的Slave赶上了,Master与其Slave自动转换为半同步复制的机制。

5.  半同步复制的功能要在Master,Slave都开启,半同步复制才会起作用;否则,只开启一边,它依然为异步复制。

由于5.7之后的版本引入的全同步,测试半同步必须用5.6的版本进行。

1.配置半同步的主从复制必须先配置好异步的主从复制,先检查一下异步的主从是否完好。

master:

[html] view plain copy

  1. mysql> mysql> show master status;
  2. +------------------+----------+--------------+------------------+-------------------+
  3. | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
  4. +------------------+----------+--------------+------------------+-------------------+
  5. | mysql_bin.000013 |      601 |              |                  |                   |
  6. +------------------+----------+--------------+------------------+-------------------+
  7. 1 row in set (0.00 sec)

slave:

[html] view plain copy

  1. mysql> show slave status\G
  2. *************************** 1. row ***************************
  3.                Slave_IO_State: Waiting for master to send event
  4.                   Master_Host: 172.17.61.131
  5.                   Master_User: repl
  6.                   Master_Port: 3306
  7.                 Connect_Retry: 60
  8.               Master_Log_File: mysql_bin.000013
  9.           Read_Master_Log_Pos: 601
  10.                Relay_Log_File: mysqld-relay-bin.000002
  11.                 Relay_Log_Pos: 374
  12.         Relay_Master_Log_File: mysql_bin.000013
  13.              Slave_IO_Running: Yes
  14.             Slave_SQL_Running: Yes
  15.            ...
  16.           Exec_Master_Log_Pos: 601
  17.               Relay_Log_Space: 548
  18.               Until_Condition: None
  19.              ...
  20.              Master_Server_Id: 10000
  21.                   Master_UUID: 82acea94-3e6f-11e8-b4a7-000c29d02daa
  22.              Master_Info_File: /u01/mysql/master.info
  23.                     SQL_Delay: 0
  24.           SQL_Remaining_Delay: NULL
  25.       Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it
  26.            Master_Retry_Count: 86400
  27.            ...
  28. 1 row in set (0.00 sec)

2.master安装半同步模块并启动(此模块就在/usr/local/mysql/lib/plugin/semisync_master.so)

PS:如果想卸载异步模块就使用uninstall即可。

[html] view plain copy

  1. mysql> show global variables like '%semi%';
  2. Empty set (0.00 sec)
  3. mysql> install plugin rpl_semi_sync_master soname 'semisync_master.so';
  4. Query OK, 0 rows affected (0.06 sec)
  5. mysql>  show global variables like '%semi%';
  6. +------------------------------------+-------+
  7. | Variable_name                      | Value |
  8. +------------------------------------+-------+
  9. | rpl_semi_sync_master_enabled       | OFF   |
  10. | rpl_semi_sync_master_timeout       | 10000 |
  11. | rpl_semi_sync_master_trace_level   | 32    |
  12. | rpl_semi_sync_master_wait_no_slave | ON    |
  13. +------------------------------------+-------+
  14. 4 rows in set (0.00 sec)

rpl_semi_sync_master_enabled参数是指是否已启动半同步

rpl_semi_sync_master_timeout参数连接salve超时的时间,单位为毫秒,默认为10秒

在配置文件中修改这两个参数并重启数据库

[html] view plain copy

  1. [root@qht131 ~]# cat /etc/my.cnf
  2. 。。。
  3. [mysqld]
  4. 。。。
  5. rpl_semi_sync_master_enabled = 1
  6. rpl_semi_sync_master_timeout = 2000

[html] view plain copy

  1. [root@qht131 ~]# service mysql restart
  2. Shutting down MySQL....                                    [  OK  ]
  3. Starting MySQL..                                           [  OK  ]

 

[html] view plain copy

  1. mysql>  show global variables like '%semi%';
  2. +------------------------------------+-------+
  3. | Variable_name                      | Value |
  4. +------------------------------------+-------+
  5. | rpl_semi_sync_master_enabled       | ON    |
  6. | rpl_semi_sync_master_timeout       | 2000  |
  7. | rpl_semi_sync_master_trace_level   | 32    |
  8. | rpl_semi_sync_master_wait_no_slave | ON    |
  9. +------------------------------------+-------+
  10. 4 rows in set (0.00 sec)

3.slave安装半同步模块

[html] view plain copy

  1. mysql> install plugin rpl_semi_sync_slave soname 'semisync_slave.so';
  2. Query OK, 0 rows affected (0.03 sec)
  3. mysql> show global variables like '%semi%';
  4. +---------------------------------+-------+
  5. | Variable_name                   | Value |
  6. +---------------------------------+-------+
  7. | rpl_semi_sync_slave_enabled     | OFF   |
  8. | rpl_semi_sync_slave_trace_level | 32    |
  9. +---------------------------------+-------+
  10. 2 rows in set (0.00 sec)

修改配置文件打开半同步

[html] view plain copy

  1. [root@qht132 backup]# cat /etc/my.cnf
  2. 。。。
  3. [mysqld]
  4. 。。。。
  5. rpl_semi_sync_slave_enabled=1

[html] view plain copy

  1. [root@qht132 backup]# service mysql restart
  2. Shutting down MySQL..                                      [  OK  ]
  3. Starting MySQL..                                           [  OK  ]

 

[html] view plain copy

  1. mysql> show global variables like '%semi%';
  2. +---------------------------------+-------+
  3. | Variable_name                   | Value |
  4. +---------------------------------+-------+
  5. | rpl_semi_sync_slave_enabled     | ON    |
  6. | rpl_semi_sync_slave_trace_level | 32    |
  7. +---------------------------------+-------+
  8. 2 rows in set (0.00 sec)

需要重新连接master服务器,半同步才会生效:

[html] view plain copy

  1. mysql> stop slave io_thread;
  2. Query OK, 0 rows affected (0.00 sec)
  3. mysql> start slave io_thread;
  4. Query OK, 0 rows affected (0.00 sec)

3.检查一下半同步是否完成

[html] view plain copy

  1. mysql> show global status like 'rpl%';
  2. +--------------------------------------------+-------+
  3. | Variable_name                              | Value |
  4. +--------------------------------------------+-------+
  5. | Rpl_semi_sync_master_clients               | 1     |
  6. | Rpl_semi_sync_master_net_avg_wait_time     | 0     |
  7. | Rpl_semi_sync_master_net_wait_time         | 0     |
  8. | Rpl_semi_sync_master_net_waits             | 0     |
  9. | Rpl_semi_sync_master_no_times              | 0     |
  10. | Rpl_semi_sync_master_no_tx                 | 0     |
  11. | Rpl_semi_sync_master_status                | ON    |
  12. | Rpl_semi_sync_master_timefunc_failures     | 0     |
  13. | Rpl_semi_sync_master_tx_avg_wait_time      | 0     |
  14. | Rpl_semi_sync_master_tx_wait_time          | 0     |
  15. | Rpl_semi_sync_master_tx_waits              | 0     |
  16. | Rpl_semi_sync_master_wait_pos_backtraverse | 0     |
  17. | Rpl_semi_sync_master_wait_sessions         | 0     |
  18. | Rpl_semi_sync_master_yes_tx                | 0     |
  19. +--------------------------------------------+-------+
  20. 14 rows in set (0.03 sec)

现在半同步已经正常工作了,主要看Rpl_semi_sync_master_clients是否不为0,Rpl_semi_sync_master_status是否为ON。如果Rpl_semi_sync_master_status为OFF,说明出现了网络延迟或Slave IO线程延迟。

4.那么可以验证一下半同步超时,是否会自动降为异步工作。可以在Slave上停掉半同步协议,然后在Master上创建数据库看一下能不能复制到Slave上。

slave上先关闭半同步:

[html] view plain copy

  1. mysql> set global rpl_semi_sync_slave_enabled = 0 ;
  2. Query OK, 0 rows affected (0.00 sec)
  3. mysql> stop slave io_thread;
  4. Query OK, 0 rows affected (0.00 sec)
  5. mysql> start slave io_thread;
  6. Query OK, 0 rows affected (0.00 sec)

master:

[html] view plain copy

  1. mysql> create database dbtest;
  2. Query OK, 1 row affected (2.01 sec)
  3. mysql> create database dbtest2;
  4. Query OK, 1 row affected (0.00 sec)

创建第一个数据库花了2.01秒,而我们前面设置的超时时间是2秒,而创建第二个数据库花了0.01秒,由此得出结论是超时转换为异步传送。可以在Master上查看半同步相关的参数值Rpl_semi_sync_master_clients和Rpl_semi_sync_master_status是否正常。

[html] view plain copy

  1. mysql> show global status like '%semi%';
  2. +--------------------------------------------+-------+
  3. | Variable_name                              | Value |
  4. +--------------------------------------------+-------+
  5. | Rpl_semi_sync_master_clients               | 0     |
  6. | Rpl_semi_sync_master_net_avg_wait_time     | 0     |
  7. | Rpl_semi_sync_master_net_wait_time         | 0     |
  8. | Rpl_semi_sync_master_net_waits             | 0     |
  9. | Rpl_semi_sync_master_no_times              | 1     |
  10. | Rpl_semi_sync_master_no_tx                 | 2     |
  11. | Rpl_semi_sync_master_status                | OFF   |
  12. | Rpl_semi_sync_master_timefunc_failures     | 0     |
  13. | Rpl_semi_sync_master_tx_avg_wait_time      | 0     |
  14. | Rpl_semi_sync_master_tx_wait_time          | 0     |
  15. | Rpl_semi_sync_master_tx_waits              | 0     |
  16. | Rpl_semi_sync_master_wait_pos_backtraverse | 0     |
  17. | Rpl_semi_sync_master_wait_sessions         | 0     |
  18. | Rpl_semi_sync_master_yes_tx                | 0     |
  19. +--------------------------------------------+-------+
  20. 14 rows in set (0.03 sec)

Rpl_semi_sync_master_clients已为0,Rpl_semi_sync_master_status已为OFF,现在主从复制已是异步状态。

5.还有一个问题,slave开启半同步后,master能自动开启半同步吗?

slave:

[html] view plain copy

  1. mysql> set global rpl_semi_sync_slave_enabled = 1;
  2. Query OK, 0 rows affected (0.00 sec)
  3. mysql> stop slave io_thread;
  4. Query OK, 0 rows affected (0.01 sec)
  5. mysql> start slave io_thread;
  6. Query OK, 0 rows affected (0.00 sec)

master:

[html] view plain copy

  1. mysql> show global status like '%semi%';
  2. +--------------------------------------------+-------+
  3. | Variable_name                              | Value |
  4. +--------------------------------------------+-------+
  5. | Rpl_semi_sync_master_clients               | 1     |
  6. | Rpl_semi_sync_master_net_avg_wait_time     | 0     |
  7. | Rpl_semi_sync_master_net_wait_time         | 0     |
  8. | Rpl_semi_sync_master_net_waits             | 0     |
  9. | Rpl_semi_sync_master_no_times              | 1     |
  10. | Rpl_semi_sync_master_no_tx                 | 2     |
  11. | Rpl_semi_sync_master_status                | ON    |
  12. | Rpl_semi_sync_master_timefunc_failures     | 0     |
  13. | Rpl_semi_sync_master_tx_avg_wait_time      | 0     |
  14. | Rpl_semi_sync_master_tx_wait_time          | 0     |
  15. | Rpl_semi_sync_master_tx_waits              | 0     |
  16. | Rpl_semi_sync_master_wait_pos_backtraverse | 0     |
  17. | Rpl_semi_sync_master_wait_sessions         | 0     |
  18. | Rpl_semi_sync_master_yes_tx                | 0     |
  19. +--------------------------------------------+-------+
  20. 14 rows in set (0.00 sec)

当Slave开启半同步后,或者当主从之间网络延迟恢复正常的时候,半同步复制会自动从异步复制又转为半同步复制,还是相当智能的。

原文地址http://www.bieryun.com/3145.html

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
安全 关系型数据库 MySQL
如何将数据从MySQL同步到其他系统
【10月更文挑战第17天】如何将数据从MySQL同步到其他系统
455 0
|
9天前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
52 14
|
21天前
|
关系型数据库 MySQL 数据库
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
94 24
|
18天前
|
监控 关系型数据库 MySQL
Flink CDC MySQL同步MySQL错误记录
在使用Flink CDC同步MySQL数据时,常见的错误包括连接错误、权限错误、表结构变化、数据类型不匹配、主键冲突和
63 16
|
3月前
|
存储 关系型数据库 MySQL
MySQL主从复制原理和使用
本文介绍了MySQL主从复制的基本概念、原理及其实现方法,详细讲解了一主两从的架构设计,以及三种常见的复制模式(全同步、异步、半同步)的特点与适用场景。此外,文章还提供了Spring Boot环境下配置主从复制的具体代码示例,包括数据源配置、上下文切换、路由实现及切面编程等内容,帮助读者理解如何在实际项目中实现数据库的读写分离。
173 1
MySQL主从复制原理和使用
|
2月前
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]
|
2月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
203 2
|
3月前
|
SQL 关系型数据库 MySQL
Mysql中搭建主从复制原理和配置
主从复制在数据库管理中广泛应用,主要优点包括提高性能、实现高可用性、数据备份及灾难恢复。通过读写分离、从服务器接管、实时备份和地理分布等机制,有效增强系统的稳定性和数据安全性。主从复制涉及I/O线程和SQL线程,前者负责日志传输,后者负责日志应用,确保数据同步。配置过程中需开启二进制日志、设置唯一服务器ID,并创建复制用户,通过CHANGE MASTER TO命令配置从服务器连接主服务器,实现数据同步。实验部分展示了如何在两台CentOS 7服务器上配置MySQL 5.7主从复制,包括关闭防火墙、配置静态IP、设置域名解析、配置主从服务器、启动复制及验证同步效果。
101 0
Mysql中搭建主从复制原理和配置
|
17天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
42 3
|
17天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
46 3
下一篇
开通oss服务