mysql8主从复制

mysql5.7时允许多线程复制,原理是同时处于prepared的事务都是可以并行执行的,因为能进入prepared阶段的说明已经拿到了锁,既然不同的事务同时拿到了锁,那么就不可能冲突,所以可以同时执行的.

AtomicInteger globalTransactionId;

thread1:{
	beginTransaction();
	excute("update user set age = 10");
	commit();
}
thread2:{
	beginTransaction();
	excute("update user set age = 9");
	commit();
}
thread3:{
	beginTransaction();
	excute("update book set name = `hello`");
	commit();
}
commit(){
	prepared();
	// 这一步可能多个线程一起进入,拿到相同的值,值相同的话表示该事务可以并行执行
	int last_committed = globalTransactionId.get();
	// 将last_committed 写入bin-log
	...
	globalTransactionId.increase();
	...
}



mysql配置
主:
sync_binlog=1 // 每执行一次事务就写入磁盘

从:
slave-parallel-type=LOGICAL_CLOCK // 事务组同时提交
slave-parallel-workers=16 // 启动多少个slave_sql_thread线程
relay_log_recovery=ON // 在从库中将relay_log_recovery设置为on,假如果碰到relay_log损坏的情形,从库会自动放弃所有未执行的relay log,重新生成一个relay log,并将从库的io线程的position重新指向新的relay log。并将sql线程的position退回到跟io线程的position保持一致,重新开始同步,这样在从库中事务不会丢失。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值