关于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

如何减少延迟

  • 最好使用内网或者专线传输binlog。尽可能不要在互联网上传输。生产环境最好在千兆网以上,可以使用bond技术进行拓展,mysql也可以在bind在特定的网卡上(bind-address=ip,set global bind_address)。如果MS部署在不同的地方,距离较远,那最好是拉穿线,至少也得保证有单独网络传输专线,如VPN 。总之,避免在慢速上传输二进制日志。
  • 将二进制日志保存在独立的存储介质上,改善IO(log-bin=/path/to/mysqlbinlog)
  • 使用多核CPU,使用多线程方式传输二进制日志。在5.6之前二进制传输是单线程的,这就相当于把并行的变成串行的,因为master在执行任务时是并发操作的,而传输日志是单线程的。
  • 如果二进制日志不是row格式的,则尽可能在insert或者update等DML操作的时候使用select。建议单独创建表或者视图
  • 尽可能减少Master的写IO,因为Master所做的事很多,既要处理自身的操作,又要写自己的binlog,还要读自己的binlog传给slave。可以建立缓存系统如memcache,减缓数据库压力。只要周期性的将数据同步给数据库。

更新架构

  • 主从服务器可以使用不同的存储引擎。M使用Innodb,利用它能够支持事务、行锁和高并发性能好等特征。而slave上可以使用Myisam,因为Myisam读性更好,节省内存,易备份。可以在MS完成主从架构之后使用alter table engine改变存储引擎,还可以在MS使用不同的数据类型,因为使用了不同的存储引擎了嘛,所以对不同的数据类型,不同的存储引擎的处理也不一样。可以在master上使用varchar,在slave上使用char,利用Myisam表的静态表特征
  • 使用M-S-Muti_Slave,中继slave可以考虑使用blackhole存储引擎。blackhole只记录日志,不写数据,就像/dev/null。利用这个特点可以让中继日志性能提示很多,但是,blackhole不支持GTIDs模式的复制,blockhole只支持传统的statement模式下的复制,row和mixed也不支持。但是平时建议使用row格式,使数据完整性能够保持很高的一致性
  • 读写分离,使用M写,S来读。在这种情况下,Master可以只保留主键和唯一索引等保证数据关系的索引,因为在写数据的时候,同时也会写索引,索引很多情况下,将会是性能下降。但是在slave上只有读的操作,此时可以针对查询做索引优化
  • 让更新频繁,且需要实时的数据查询放到Master上的场景下。可以通过持久化session,让发生修改的用户先看到结果,其他人等待同步后在查看slave。但是开发上就比较复杂。一般的情况,通过借助缓存如memcache来做到这一点,用户写的数据先存储在memcache上,然后每个一段时间,在同步到master上,而其他用户访问的使用可以先访问缓存memcache,访问没有的话才到slave或者master上读取。由于memcache是把数据存储在内存中因此,访问速度和性能上都会有改善。

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核心数和数据库的数量两方面来指定。

关于提示replication性能的更多相关文章

  1. 提高 ASP.NET Web 应用性能

    转载:http://www.codeceo.com/article/24-ways-improve-aspnet-web.html 在这篇文章中,将介绍一些提高 ASP.NET Web 应用性能的方法 ...

  2. .NET开发人员必看:提高ASP.NET Web应用性能的24种方法和技巧

    那性能问题到底该如何解决?以下是应用系统发布前,作为 .NET 开发人员需要检查的点. 1.debug=「false」 当创建 ASP.NET Web应用程序,默认设置为「true」.开发过程中,设置 ...

  3. (转)SQL Server 性能调优(cpu)

    摘自:http://www.cnblogs.com/Amaranthus/archive/2012/03/07/2383551.html 研究cpu压力工具 perfom SQL跟踪 性能视图 cpu ...

  4. Android性能优化典范(二)

    Google前几天刚发布了Android性能优化典范第2季的课程,一共20个短视频,包括的内容大致有:电量优化,网络优化,Wear上如何做优化,使用对象池来提高效率,LRU Cache,Bitmap的 ...

  5. android app性能优化大汇总(google官方Android性能优化典范 - 第2季)

    Google前几天刚发布了Android性能优化典范第2季的课程,一共20个短视频,包括的内容大致有:电量优化,网络优化,Wear上如何做优化,使用对象池来提高效率,LRU Cache,Bitmap的 ...

  6. Android性能优化典范 - 第2季

    Google发布了Android性能优化典范第2季的课程,一共20个短视频,包括的内容大致有:电量优化,网络优化,Wear上如何做优化,使用对象池来提高效率,LRU Cache,Bitmap的缩放,缓 ...

  7. 性能调优之提高 ASP.NET Web 应用性能的 24 种方法和技巧

    性能调优之提高 ASP.NET Web 应用性能的 24 种方法和技巧   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对 ...

  8. [MySQL Reference Manual]17 Group Replication

    17 Group Replication 17 Group Replication 17.1 Group Replication后台 17.1.1 Replication技术 17.1.1.1 主从复 ...

  9. 提高 ASP.NET Web 应用性能的 24 种方法和技巧(转载)

    在这篇文章中,将介绍一些提高 ASP.NET Web 应用性能的方法和技巧.众所周知,解决性能问题是一项繁琐的工作,当出现性能问题,每个人都会归咎于编写代码的开发人员. 以下为译文 那性能问题到底该如 ...

随机推荐

  1. hadoop报JAVA_HOME is not set暂时解决办法

    直接在etc/hadoop/hadoop-env.sh中 export JAVA_HOME=XXX

  2. YTU 2420: C语言习题 不等长字符串排序

    2420: C语言习题 不等长字符串排序 时间限制: 1 Sec  内存限制: 128 MB 提交: 460  解决: 239 题目描述 在主函数中输入n(n<=10)个不等长的字符串.用另一函 ...

  3. Pycharm中如何安装python库

    1首先打开pycharm工具,选择File中的Setting选项,如下图所示 2在打开的setting界面中我们点击python的解释器,你会看到很多导入的第三方库,如下图所示,点击最右边的加号 3在 ...

  4. COGS-2049 疯狂动物城

    Description 你意外来到了一个未知的星球, 这里是一个动物乌托邦, 生活着一群拥有非凡智力的动物. 你遇到了一个叫做尼克的狐狸, 他准备给他的 GF 过生日 . 他将制作一个巨大的多层蛋糕, ...

  5. Fleck websocket官方事例

    Fleck websocket官方事例 server: using Fleck;using System;using System.Collections.Generic;using System.L ...

  6. poj 3468 A Simple Problem with Integers(线段树 插线问线)

    #include<iostream> #include<stdio.h> #include<string.h> #define NN 2500000 using n ...

  7. 【POJ 3468】 A Simple Problem with Integers

    [题目链接] 点击打开链接 [算法] 本题用线段树很容易写,但是,笔者为了练习树状数组,就用树状数组的方法做了一遍 我们不妨引入差分数组c, 则sum(n) = c[1] + (c[1] + c[2] ...

  8. angularJS 的双向数据绑定

    input 里面的vale="变量名";加上ng-model="变量名";控制器的变量名会根据视图层的数据改变而改变,而渲染内容也会根据控制器里面的变量改变而改 ...

  9. "Activity" 总结

    1.什么是Activity? 1.四大组件之一 2.通常一个界面对应一个activity 3.是Context的子类 4.同时实现window.callback和keyevent.callback回调 ...

  10. codeforces 126B

    Asterix, Obelix and their temporary buddies Suffix and Prefix has finally found the Harmony temple. ...