MysqL主从复制_模式之GTID复制

基于GTID的复制是从Mysql5.6开始支持的一种新的复制方式,此方式与传统基于日志的方式存在很大的差异,在原来的基于日志的复制中,从服务器连接到主服务器并告诉主服务器要从哪个二进制日志的偏移量开始执行增量同步,这时我们如果指定的日志偏移量不对,这与可能造成主从数据的不一致,而基于GTID的复制会避免。

在基于GTID的复制中,首先从服务器会告诉主服务器已经在从服务器执行完了哪些事务的GTID值,然后主库会有把所有没有在从库上执行的事务,发送到从库上进行执行,并且使用GTID的复制可以保证同一个事务只在指定的从库上执行一次,这样可以避免由于偏移量的问题造成数据不一致。

什么是GTID,也就是全局事务ID,其保证为每一个在主上提交的事务在复制集群中可以生成一个唯一的ID。

一个GITD由两部分组成的,分别是source_id 和transaction_id,GTID=source_id:transaction_id,其中source_id就是执行事务的主库的server-uuid值,server-uuid值是在mysql服务首次启动生成的,保存在数据库的数据目录中,在数据目录中有一个auto.conf文件,这个文件保存了server-uuid值(唯一的)。而事务ID则是从1开始自增的序列,表示这个事务是在主库上执行的第几个事务,Mysql会保证这个事务和GTID是一比一的关系。

配置主数据库服务器需要做的大概和传统的主从配置差不多,需要起码的在主服务器上建立复制账号,还要配置数据库日志文件的目录,这是必须的启动bin_log日志。

可以指定bin_log存放目录,而不是用数据目录,分开存储是个好习惯,特别是如果把日志和数据放在不同的磁盘分区上,这样不但可以避免日志的增长把数据磁盘分区占满,也可以提高了磁盘IO。如bin_log = /usr/local/mysql/log/mysql-bin。

优点

   A:很方便的进行故障转移,因为GTID是全局唯一的标识符,所以就很简单知道哪些事务在从服务器没有执行,在多个从服务器也没必要进行多个日志偏移量配置了.

   B:从库和主库的数据一致性。

缺点

  A:故障处理比日志处理复杂。

  B:执行语句的一些限制。

开始配置GTID主从复制

虚拟机IP:192.168.136.142(Master)、192.168.136.143(Slave)

Mysql版本:5.6(5.7的配置与5.6稍微有些不一样,如果你的Mysql版本是5.7,可以参考其他文章)

首先配置一下主服务器,编辑/etc/my.cnf

[mysqld]

port =3306socket = /tmp/mysql.sock

basedir = /usr/local/mysql

datadir = /data/mysql

pid-file = /data/mysql/mysql.pidserver-id =142log_bin = mysql-bin

bin_log = /usr/local/mysql/log/mysql-bin

binlog_format = ROW       //建议row

log-slave-updates=true      //在从服务器进入主服务器传入过来的修改日志所使用,在Mysql5.7之前主从架构上使用gtid模式的话,必须使用此选项,在Mysql5.7取消了,会增加系统负载。

enforce-gtid-consistency=true  // 强制gtid一直性,用于保证启动gitd后事务的安全;

gtid-mode=on //开启gtid模式

master_info_repository=TABLE

relay_log_info_repository=TABLE //指定中继日志的存储方式,默认是文件,这样配置是使用了 两个表,是INNODB存储引擎,好处是当出现数据库崩溃时,利用INNODE事务引擎的特点,对这两个表进行恢复,以保证从服务器可以从正确位置恢复数据。

sync-master-info=1//同步master_info,任何事物提交以后都必须要把事务提交以后的二进制日志事件的位置对应的文件名称,记录到master_info中,下次启动自动读取,保证数据无丢失

slave-parallel-workers=2//设定从服务器的启动线程数,0表示不启动

binlog-checksum=CRC32          //主服务端在启动的时候要不要校验bin-log本身的校验码

master-verify-checksum=1//都是在服务器出现故障情况下,读取对服务器有用的数据

slave-sql-verify-checksum=1

binlog-rows-query-log_events=1//启用后,可用于在二进制日志记录事件相关信息,可降低故障排除复杂度(并非强制启动)

report-port=3306

report-host=192.168.136.142

配置完成之后别忘了重启Mysql。

查看一下master状态,多了一项。

主服务进入Mysql,命令行执行授权

grant replication client,replication slave on *.* to root@'192.168.136.%'identified by'root123';  //ip段与账号密码

flush privileges;  //刷新权限

show grantsforroot@'192.168.136.%';

启动配置之前,我们同样需要对从服务器进行初始化。对从服务器初始化的方法基本和基于日志点是相同的,只不过在启动了GTID模式后,在备份中所记录的就不是备份时的二进制日志文件名和偏移量了,而是记录的是备份时最后的GTID值。

查看一下有哪些数据库,退出Mysql终端,进入一个目录,把目标库备份一下,这里是testdb


mysqldump --single-transaction --master-data=2--triggers --routines --database testdb -uroot -p > testdb.sql

备份完成之后,查看一下sql文件内容。

然后把当前sql文件拷贝到从服务器,这里使用scp命令。

scp -P22 testdb.sql root@192.168.136.143:/data/mysql/

拷贝完之后,进入从服务器Mysql终端,创建目标数据库,然后倒入到从库。

mysql -uroot -p testdb < testdb.sql

倒入成功之后,接下来配置从服务器,与主服务器配置大概一致,从服务器可以在配置文件里面添加 read_only=ON ,使从服务器只能进行读取操作,此参数对超级用户无效,并且不会影响从服务器的复制;

port =3306socket = /tmp/mysql.sock

basedir

= /usr/local/mysql

datadir = /data/mysql

pid-file = /data/mysql/mysql.pid

user = mysql

bind-address =0.0.0.0server-id =143

log_bin = mysql-bin

bin_log = /usr/local/mysql/log/mysql-bin

binlog_format = ROW    //建议row

log-slave-updates=trueenforce-gtid-consistency=truegtid-mode=on

master_info_repository=TABLE 

relay_log_info_repository=TABLE  //指定中继日志的存储方式,默认是文件,这样配置是使用了 两个表,是INNODB存储引擎,好处是当出现数据库崩溃时,利用INNODE事务引擎的特点,对这两个表进行恢复,以保证从服务器可以从正确位置恢复数据。

sync-master-info=1slave-parallel-workers=2  //开启线程数,0就表示禁用线程binlog-checksum=CRC32

master-verify-checksum=1slave-sql-verify-checksum=1binlog-rows-query-log_events=1report-port=3306report-host=192.168.136.143

read_only = on //这个参数主要保证从服务器的数据安全性

别忘了重启mysql。

然后进入mysql终端,使用change master 配置主从

change master to master_host='192.168.136.142',master_user='root',master_passwrd='root123',master_auto_position=1;

start slave;  //配置完成启动slave

 在主数据库端查看一下


配置成功了。然后试着在主库上执行一条insert 语句,在从库上查看,OK,数据也有了~~~

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

推荐阅读更多精彩内容