标签:
关于GTIDs的二进制日志:
gtid_next: 下一个事务的编号,是master传给slave的
如SET @@SESSION.GTID_NEXT= ‘c09756b8-a7e7-11e5-9468-000c29df5442:4‘ 则下一个事务为4
1.正常情况,下一次收到的gtid是4,slave将同步,然后设置gtid为4。
2.收到重复的,网络问题:延迟,包重发等。mysql会忽略掉重复的,避免出错
3.收到大于gtid_next的GTID。有可能网络丢包等原因,mysql slave将等待新的事务传输,要么报错
因此:这个基于GTIDs的复制,数据的一致性好,易于管理。自动化
show variables like ‘%gtid%‘;
| gtid_mode | ON |
| gtid_next | AUTOMATIC |
还有一个优点:易于调整架构
只要改变master_host。就可以调整架构,如MS、MSS。而不需要知道二进制日志文件名和文件的位置。全都是基于gtid的
root@localhost: (none) 10:54 > change master to
-> master_host=‘192.168.88.123‘,
-> master_user=‘rep‘,
-> master_password=‘redhat‘,
-> master_auto_position=1;
如何提示复制的性能:
基本是就是延迟的问题,在没有发生故障的情况下,MS之间的数据不一致也是常用的
延迟分类:关键是克服经常性延迟的问题
*经常性延迟:高峰期,周期性
暂时性延迟:导入数据,计算大表。slave无法在短时间满足
原因:网络带宽、IO
如何减少延迟:
更新架构:
replication容量
在master上不写新数据的情况下,将slave暂停一段时间(M),再重新开启,此时到slave的数据追到和Master的一致的这段时间(N),则replication容量可以表示为N:M,一般1:3甚至比这个值更小,replication性能才能说不错。比如M停60min,slave最好在20min之内就可以完成数据的一致性。
多线程方式传输二进制日志
(MySQL5.6之后,在之前可以使用mysql transfer 淘宝对mysql的多线程的patch http://csrd.aliapp.com/?p=1590)
一般在操作量(QPS)比较大的情况下,多线程的优势尤为明显
只能适用于GTIDs模式下
只有对不同的库执行的操作才使用多线程传输,同一库的不同的操作只能用单线程。所以在业务上,可以采用分库的方法,来提升replication的性能,默认多线程是不开启的。可以设定slave-parallel-workers=N(默认为0,表示不开启),N可以根据cpu核心数和数据库的数量两方面来指定。
标签:
原文地址:http://www.cnblogs.com/wxl-dede/p/5070750.html