并行复制(MTS:enhanced Multi-threaded slave)

5.7.2 支持单库加强型多线程slave(多个sql work线程),mariadb 10.0.5支持html

  • 原理mysql

    • slave利用事务组提交的特性(To provide parallel execution of transactions in the same schema, MariaDB 10.0 and MySQL 5.7 take advantage of the binary log group commit optimization),在slave 多个sql worker线程进行并行回放
    • master依据group commit的并行性,在binary log进行标记,slave使用master提供的信息并行执行事务
  • 注意事项sql

    • 级联复制场景,其余slave将会出现并行性更小(并行度不同),使用binlog server作替代方案
  • 配置多线程

    • mysql 5.7
      • slave_parallel_type=logical_clock 默认为database,使用db并行方式,logical_clock使用逻辑时钟的并行模式
      • slave_parallel_workers=16 设置worker线程数
      • binlog_group_commit_sync_delaybinlog_group_commit_sync_no_delay_count 在master延时事务提交,增长group commit事务数
    • mariadb参数
      • slave_parallel_threads=16 也支持多源复制
      • slave_parallel_mode=conservative 10.1.3开始支持optimistic模式,经过启发性方式减小冲突,若是发生冲突,将事务进行回滚 ;Conservative默认值,使用group commit发现潜在的并行事件,在一个group commit中的事务写到binlog时拥有相同的commit id(cid);minimal仅仅commit阶段是并行,其余事务应用发生是串行的,同时也关闭out-of-order(使用不一样domain id)并行复制
      • binlog_commit_wait_countbinlog_commit_wait_usec 调整master进行group commit的事务数
      • slave_parallel_max_queued 限制每一个线程的队列事件数,提升worker线程处理能力
      • slave_domain_parallel_threads worker线程由全部多源master链接共享,建议大于slave_parallel_threads
  • 查看状态app

    • show processlist 检查worker线程的状态
    • mariadb的状态变量BINLOG_COMMITSBINLOG_GROUP_COMMITS
  • 性能测试dom

输入图片说明

相关文章
相关标签/搜索