Mysql 的GTID主从复制方式

Mysql 的GTID主从复制方式

GTID的作用

GTID 是‘全局事务ID’的意思,在 MySQL5.6 中被添加进来

以前 MySQL 的主从复制是基于复制点的,slave 从 master 二进制日志的某个位置开始复制

有了 GTID 之后,就多了一种复制方式,MySQL 在每个事务操作时都会分配一个全局唯一的ID,slave 就可以基于这个ID进行复制,只要是自己没有复制过的事务,就拿过来进行复制,可以不用关心具体的复制位置了

基于GTID复制的优缺点

优点

可以更方便的故障转移,出现问题时,多个slave不用根据新master的二进制偏移量来同步了

主从配置更简单,在后面的配置过程中就可以看到

缺点

增加了SQL限制,例如不可以使用 create table ... select ... 这种方式直接建表插数据,必须分开,而在基于偏移量复制时是没有任何限制的

MySQL版本限制,GTID是5.6时加入的,在5.7中被进一步完善,建议在5.7或者5.6的后期版本中使用,所以老版本无法使用,而且如果你的MySQL集群高可用方案使用的是MMM,那么也无法使用GTID,MMM只支持偏移量复制,MHA可以支持GTID

GTID主从复制的配置思路

配置过程

准备两台MySQL

Master中的操作

(1)确定 server uuid 不同

首先要确保两个MySQL的 server_uuid 不同,例如使用复制出来的两台虚机,或者在Docker中使用同一MySQL镜像的两个容器时,就会出现 uuid 相同的情况,会使复制失败

检查两个MySQL的uuid

mysql> SHOW VARIABLES like '%server_uuid%';

值相同时需要修改,查看 my.cnf 中 datadir 的位置,其目录下有一个文件 auto.cnf,把其中的 server-uuid 值改一下,注意不要增减长度,例如把最后一个字符改下即可

(2)配置GTID

修改 /etc/my.cnf,在[mysqld]下添加:

[mysqld]

...

log-bin=mysql-bin

server-id=221

gtid_mode=on

enforce-gtid-consistency=true

...

重启MySQL,登录客户端检查一下GTID是否已经开启

mysql> show global variables like '%gtid%';

配置的那两项为'ON'时说明配置成功

(3)导出数据

开始复制之前要使master与slave中的初始数据相同,使用适合自己的工具进行数据同步,例如使用 mysqldump

mysqldump --single-transaction --master-data=2 --triggers --routines --all-databases -uroot -p111111 > all.sql

把生成的 all.sql 发送到 slave

(4)创建复制用户

创建一个用户,用于slave执行复制

mysql> GRANT REPLICATION SLAVE ON *.* to 'gtidrepli'@'%' identified by '123456';

Slave中的操作

(1)配置GTID

修改 /etc/my.cnf,在[mysqld]下添加:

server_id=207

log-bin=mysql-bin

read_only=on

gtid_mode=on

enforce-gtid-consistency=true

master_info_repository=TABLE

relay_log_info_repository=TABLE

保存后重启MySQL

(2)导入数据

mysql -uroot -p111111 < all.sql

(3)指定Master

使用 change master 命令配置 master 信息

mysql> change master to master_host='192.168.31.221',master_user='gtidrepli',master_password='123456',master_auto_position = 1;

(4)启动slave

mysql> start slave;

检查slave状态

mysql> show slave status \G;

以下两项为 YES 说明复制成功

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

可以到master中做一些测试操作,到slave中检查是否已经同步

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容