mysql writeset_浅析MySQL的WriteSet并行复制

本文介绍了MySQL的WriteSet并行复制技术,包括库间并发、组提交和WriteSet的发展历程。WriteSet通过记录最近修改的数据,智能打包不冲突的事务到同一组,提高并行复制效率,提供更好的性能和灵活性。
摘要由CSDN通过智能技术生成

【历史背景】

岁月更迭中我已经从事mysql-dba这个工作三个年头,见证mysql从“基本可用”,“边缘系统可以用mysql”,“哦操!你怎么不用mysql”;

正所谓!“一个数据库的境遇既取决于历史的进程,取决于它的自我奋斗!”,关于“历史的进程”在此不表,关于“自我奋斗”这里也只想谈一下并行复制的几个关键时间结点

总的来说mysql关于并行复制到目前为止经历过三个比较关键的时间结点“库间并发”,“组提交”,“写集合”;真可谓是江山代有人才出,前浪死在沙滩上;总的来说就后面的比前面的不知道高到哪里去了!

【库间并发】

库间并发的理论依据是这样的 ---- 一个实例内可能会有多个库(schema),不同的库之间没有什么依赖关系,所以在slave那边为每一个库(schema)单独起一个sql线程,这样就能通过多线程并行复制的方式来提高主从复制的效率。

这个理论听起来没问题,但是事实上一个实例也就一个业务库,所以这种库间并发就没什么作用了;也就是说这个方式的适用场景比较少,针对这个不足直到“组提交”才解决!

【组提交】

组提交的理论依据是这样的 --- 如果多个事务他们能在同一时间内提交,这个就间接说明了这个几个事务锁上是没有冲突的,也是就说他们各自持有不同的锁,互不影响;逻辑上我们几个事务看一个组,在slave以“组”为单位分配给sql线程执行,这样多个sql线程就可以并行跑了;而且不在以库为并行的粒度,效果上要比“库间并发”要好一些。

这个事实上也有一些问题,因为它要求库上要有一定的并发度

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值