zoukankan      html  css  js  c++  java
  • MySQL Replication--基于WriteSet的多线程复制

    基础知识

    基于 COMMIT_ORDER 的并行复制只有在有压力的情况下才可能会形成一组,压力不大的情况下在从库的并行度并不会高。但是基于 WRITESET 的并行复制目标就是在ORDER_COMMIT 的基础上再尽可能的降低 last commit ,这样在从库获得更好的并行度(即便在主库串行执行的事务在从库也能并行应用)。它使用的方式就是通过扫描 Writeset 中的每一个元素(行数据的 hash 值)在一个叫做 Writeset 的历史 MAP(行数据的 hash 值和 seq number 的一个MAP)中进行比对,寻找与当前事务所操作的数据发生"数据冲突"后的最近时间点(Last Committed).

    计算PKE方式

    在sql pl_write_set_handler.cc的add_pke函数中有如下注释:

    The next section extracts the primary key equivalent of the rows that are
    changing during the current transaction.
    
    1. The primary key field is always stored in the key_part[0] so we can
    simply read the value from the table->s->keys.
    
    2. Along with primary key we also need to extract the unique key values to
       look for the places where we are breaking the unique key constraints.
    
    These keys (primary/unique) are prefixed with their index names.
    
    In MySQL, the name of a PRIMARY KEY is PRIMARY. For other indexes, if
    you do not assign a name, the index is assigned the same name as the
    first indexed column, with an optional suffix (_2, _3, ...) to make it
    unique.
    
    example :
       CREATE TABLE db1.t1 (i INT NOT NULL PRIMARY KEY, j INT UNIQUE KEY, k INT
    						UNIQUE KEY);
    
       INSERT INTO db1.t1 VALUES(1, 2, 3);
    
       Here the write set string will have three values and the prepared value
    before hash function is used will be :
    
       i -> PRIMARYdb13t1211 => PRIMARY is the index name (for primary key)
    
       j -> jdb13t1221       => 'j' is the index name (for first unique key)
       k -> kdb13t1231       => 'k' is the index name (for second unique key)
    
    Finally these value are hashed using the murmur hash function to prevent
    sending more for certification algorithm.
    

    计算PKE流程

    1. 如果表中存在索引:
    2. 将数据库名,表名信息写入临时变量
    3. 循环扫描表中每个索引:
    4. 如果不是唯一索引:
    5. 退出本次循环继续循环。
    6. 循环两种生成数据的方式(二进制格式和字符串格式):
    7. 将索引名字写入到pke中。
    8. 将临时变量信息写入到pke中。
    9. 循环扫描索引中的每一个字段:
    10. 将每一个字段的信息写入到pke中。
    11. 如果字段扫描完成:
    12. 将pke生成hash值并且写入到写集合中。
    13. 如果没有找到主键或者唯一键记录一个标记,后面通过这个标记来
    14. 判定是否使用Writeset的并行复制方式

    参考资料

    https://zhuanlan.zhihu.com/p/87958886

  • 相关阅读:
    帧同步与状态同步的区别
    spread语法解析与使用
    CoordinatorLayout自定义Bahavior特效及其源码分析
    更便捷的Android多渠道打包方式
    用Dart&Henson玩转Activity跳转
    用RxJava处理复杂表单验证问题
    用RxJava处理嵌套请求
    技术与业务的抉择————论程序员的“瓶颈”问题
    Android Studio单元测试入门
    Android一键多渠道分发打包实战和解析
  • 原文地址:https://www.cnblogs.com/gaogao67/p/14643568.html
Copyright © 2011-2022 走看看