GTID的基础知识
-
AUTO_POSITION的原理
- MySQL Server 记录了所有已经执行了的事务的GTID,包括复制过来的。可用过系统变量Gtid_executed查看。
- Slave记录了所有从master接收过来的事务的GTID。可通过Retrieve_gtid_set查看(包括已执行的和未执行的)
- Slave连接到Master时,会把gtid_executed中的gtid发给master. Master会自动跳过这些事务,只将没有复制的事物发送到Slave去。
-
Retrieved_Gtid_Set: c05a182a-48c9-11e6-8b56-001188be19c0:2
Executed_Gtid_Set: c05a182a-48c9-11e6-8b56-001188be19c0:1-2 有一个等价的表在mysql下为gtid_executed
GTID的受限语句检测
小技巧
GTID不支持的语句/事务
CREATE TABLE … SELECT
事务中同时使用了支持事务和不支持事务的引擎。
在事务中使用临时表 BEGIN;
INSERT INTO innodb_tbl(…);
CREATE TEMPORARY TABLE temp1;
...
COMMIT;
CREATE TABLE … SELECT
事务中同时使用了支持事务和不支持事务的引擎。
BEGIN;
INSERT INTO innodb_tbl(…);
INSERT INTO myisam_tbl(…);
COMMIT;
INSERT INTO innodb_tbl(…);
INSERT INTO myisam_tbl(…);
COMMIT;
在事务中使用临时表 BEGIN;
INSERT INTO innodb_tbl(…);
CREATE TEMPORARY TABLE temp1;
...
COMMIT;
小技巧
启用GTID前,检测系统中是否有GTID不支持的语句/事务,提前处理。
全局系统变量enforce-gtid-consistency
OFF 不检测是否有GTID不支持的语句/事务
WARN 当发现不支持的语句/事务时,返回警告,并在日志中记录警告信息。
ON 当发现语句/事务不支持GTID时,返回错误。 ----所以上面报错了
在线上的数据库服务器或测试环境中,开启WARN模式。 +---------+------+---------------------------------------------------------------+
| Level | Code | Message |
+---------+------+---------------------------------------------------------------+
| Warning | 1786 | Statement violates GTID consistency: CREATE TABLE ... SELECT. |
+---------+------+---------------------------------------------------------------+
2016-07-11T10:48:34.627976Z 2 [Warning] Statement violates GTID consistency: CREATE TABLE ... SELECT.
处理完GTID不支持的语句后,再启用GTID。
全局系统变量enforce-gtid-consistency
OFF 不检测是否有GTID不支持的语句/事务
WARN 当发现不支持的语句/事务时,返回警告,并在日志中记录警告信息。
ON 当发现语句/事务不支持GTID时,返回错误。 ----所以上面报错了
在线上的数据库服务器或测试环境中,开启WARN模式。 +---------+------+---------------------------------------------------------------+
| Level | Code | Message |
+---------+------+---------------------------------------------------------------+
| Warning | 1786 | Statement violates GTID consistency: CREATE TABLE ... SELECT. |
+---------+------+---------------------------------------------------------------+
2016-07-11T10:48:34.627976Z 2 [Warning] Statement violates GTID consistency: CREATE TABLE ... SELECT.
处理完GTID不支持的语句后,再启用GTID。
- 连接:
-
http://blog.itpub.net/29096438/viewspace-2060975/
Mysql5.7多线程并发复制
- 基本搭建过程可参如下文档:
- http://www.innomysql.com/article/16317.html
-
http://www.innomysql.com/innosqlmysql并行复制的实现与配置/
-
- mysql5.6多线程复制:基于datababase/schema的
- mysql5.7多线程复制:继承5.6的同时,基于事务执行的逻辑时钟(Logical Clock)的并发(5.7以来)
-
具体区别如下:
两种类型的并发
基于库(Database/Schema)的并发(5.6以来)
Binlog中记录语句使用的所有的库的名字。
不同库上的事务可以并发执行,同库的事务顺序执行。
基于事务执行的逻辑时钟(Logical Clock)的并发(5.7以来)。
Binlog中记录事务执行时的相对顺序信息。
基本原理是锁的冲突检测,因此也叫基于锁的并发机制。
基于锁的并发复制的原理
待续。。。。
-
在线快速切换为并发复制:注意:如果主5.6 从5.7使用LOGICAL_CLOCK的模式可能会出现如下类型错误
-
mysql> STOP SLAVE SQL_THREAD;
-
mysql> SET GLOBAL slave_parallel_workers = 8; #并发线程数量
-
mysql> SET GLOBAL slave_parallel_type = “ LOGICAL_CLOCK” ; #or DATABASE
- mysql> START SLAVE SQL_THREAD
-
mysql> STOP SLAVE SQL_THREAD;
-
Last_Errno: 1756
Last_Error: … The slave coordinator and worker threads are stopped, possibly leaving data in inconsistent state. A restart should restore consistency automatically, although using non-transactional storage for data or info tables or DDL queries could lead to problems. In such cases you have to examine your data (see documentation for details). 参考文档:http://imysql.com/2016/06/02/mysql-faq-5-6-to-5-7-replicaton-failure.shtml
MySQL-5.7的半同步复制
先了解一下什么是半同步,什么是同步,什么是异步
同步复制: 直到所有的slave都commit了事务之后,此时才返回信息给客户端;缺点:完成一个事务的延迟可能很大
半同步复制: 5.7无损半同步:master在收到slave的应答之后才commit事务 更多详细信息可参考文档:http://mp.weixin.qq.com/s?__biz=MzIwNzEzNDkxNQ==&mid=400915320&idx=1&sn=58dcc499cbcedcd827002acd77c30d60&scene=4#wechat_redirect 5.6半同步:master在commit之后才等待salve的应答
异步复制: Master将事件写入binlog,但并不知道Slave是否或何时已经接收且已处理。在异步复制的机制的情况下,如果Master宕机,事务在Master上已提交,但很可能这些事务没有传到任何的Slave上。假设有Master->Salve故障转移的机制,此时Slave也可能会丢失事务
同步复制: 直到所有的slave都commit了事务之后,此时才返回信息给客户端;缺点:完成一个事务的延迟可能很大
半同步复制: 5.7无损半同步:master在收到slave的应答之后才commit事务 更多详细信息可参考文档:http://mp.weixin.qq.com/s?__biz=MzIwNzEzNDkxNQ==&mid=400915320&idx=1&sn=58dcc499cbcedcd827002acd77c30d60&scene=4#wechat_redirect 5.6半同步:master在commit之后才等待salve的应答
异步复制: Master将事件写入binlog,但并不知道Slave是否或何时已经接收且已处理。在异步复制的机制的情况下,如果Master宕机,事务在Master上已提交,但很可能这些事务没有传到任何的Slave上。假设有Master->Salve故障转移的机制,此时Slave也可能会丢失事务
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29096438/viewspace-2122065/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29096438/viewspace-2122065/
288

被折叠的 条评论
为什么被折叠?



