【MySQL】开启并行复制

一、介绍

在官方的 5.6 版本之前,MySQL 只支持单线程复制,由此在主库并发高、TPS 高时就会出现严重的主备延迟问题。

如果备库执行日志的速度持续低于主库生成日志的速度,那么主从延迟就有可能成了小时级别。而且对于一个压力持续比较高的主库来说,备库很可能永远都追不上主库。

1>MySQL 5.6版本的并行复制策略

官方 MySQL5.6 版本,支持了并行复制,只是支持的粒度是按库并行。这个策略的并行效果,取决于压力模型。如果在主库上有多个 DB,并且各个 DB 的压力均衡,使用这个策略的效果会很好。

优点:实现逻辑简单,binlog格式同时支持statement和row。

缺点:如果热点数据在同一个DB,则没有并行效果了。另外在企业级架构设计时,DBA会用多实例单库(共享存储,多个mysql实例)的模式来分解多个DB的并行压力。

2>MySQL 5.7版本的并行复制策略

在官方的 MySQL5.7 版本中,由参数 slave-parallel-type 来控制并行复制策略:

  1. 配置为 DATABASE,表示使用 MySQL 5.6 版本的按库并行策略;
  2. 配置为 LOGICAL_CLOCK,代表 MySQL 5.7 这个引入的新的并行策略。

原理:redo log组提交(group commit)策略,为同一组一起提交的事务维护一个commit_id,并写入binlog日志。日志传到备库后,coordinator会以轮询的方式将相同commit_id的事务分发到多个worker执行,待一组执行完成后,再取下一批。

MySQL 5.7.22 版本里,MySQL 增加了一个新的并行复制策略,基于 WRITESET 的并行复制。新增了一个参数 binlog-transaction-dependency-tracking,用来控制是否启用这个新策略,默认为commit_order,即上面介绍的这种。

二、开启并行复制

 

mysql> stop slave sql_thread;

mysql> set global slave_parallel_type='LOGICAL_CLOCK';

mysql> set global slave_parallel_workers=8;

mysql> set global binlog_transaction_dependency_tracking=COMMIT_ORDER;

mysql> start slave sql_thread;

注意

在MySQL 5.7.22中,默认binlog_transaction_dependency_tracking=commit_order,但是slave_parallel_type=database,此时我们以slave_parallel_type=database为准。

三、优化选项

1>设置并发线程数

slave_parallel_workers

建议把这个值设置为 8~16 之间最好(32 核物理机的情况),毕竟备库还有可能要提供读查询,不能把 CPU 都吃光了。

2>binlog组提交控制

binlog_group_commit_sync_delay 参数,表示延迟多少微秒后才调用 fsync;

binlog_group_commit_sync_no_delay_count 参数,表示累积多少次以后才调用 fsync。

这两个参数是用于故意拉长 binlog 从 write 到 fsync 的时间,以此减少 binlog 的写盘次数。在 MySQL 5.7 的并行复制策略里,它们可以用来制造更多的“同时处于 prepare 阶段的事务”。这样就增加了备库复制的并行度。

也就是说,这两个参数,既可以“故意”让主库提交得慢些,又可以让备库执行得快些。在 MySQL 5.7 处理备库延迟的时候,可以考虑调整这两个参数值,来达到提升备库复制并发度的目的。

 

 

 

转载于:https://my.oschina.net/u/3478888/blog/3004146

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
开启MySQL并行复制,需要执行以下步骤: 1. 确保MySQL版本为5.6以上,并且服务器配置符合要求(如有多核CPU、足够的内存等)。 2. 在主服务器(master)的my.cnf配置文件中添加以下内容: ``` [mysqld] ... binlog_format=ROW log_slave_updates=1 slave_parallel_workers=4 ``` 其中,binlog_format设置为ROW,log_slave_updates设置为1表示将从服务器(slave)更新操作也写入二进制日志中,slave_parallel_workers设置为并行复制的工作线程数(可以根据实际情况进行调整)。 3. 在从服务器(slave)的my.cnf配置文件中添加以下内容: ``` [mysqld] ... relay_log_info_repository=TABLE relay_log_recovery=1 relay_log_recovery=1 ``` 其中,relay_log_info_repository设置为TABLE,relay_log_recovery设置为1表示在从服务器启动时自动进行中继日志恢复。 4. 在从服务器上执行以下命令: ``` CHANGE MASTER TO MASTER_HOST='master_host_name', MASTER_USER='replication_user', MASTER_PASSWORD='replication_password', MASTER_AUTO_POSITION=1; ``` 其中,MASTER_HOST设置为主服务器的主机名或IP地址,MASTER_USER和MASTER_PASSWORD设置为用于复制的用户名和密码,MASTER_AUTO_POSITION设置为1表示使用GTID(Global Transaction ID)方式进行复制。 5. 启动从服务器,并确认复制是否正常工作。 以上就是开启MySQL并行复制的步骤,需要注意的是,在使用并行复制时,需要确保主从服务器的配置相同,否则可能会导致复制失败。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值