位置: 编程技术 - 正文

MySQL 5.7增强版Semisync Replication性能优化(mysql 5.7 8.0)

编辑:rootadmin

推荐整理分享MySQL 5.7增强版Semisync Replication性能优化(mysql 5.7 8.0),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql 5.7.13,mysql 5.7.1,mysql5.7最新版,mysql 5.7.1,mysql5.7最新版,mysql 5.7.1,mysql5.7最新版,mysql 5.7.1,内容如对您有帮助,希望把文章链接给更多的朋友!

一 前言

前文 介绍了5.5/5.6 版本的MySQL semi sync 基础原理和配置,随着MySQL 5.7 的发布,新版本的MySQL修复了semi sync 的一些bug 并且增强了功能。

支持发送binlog和接受ack的异步化;支持在事务commit前等待ACK;在server层判断备库是否要求半同步以减少Plugin锁冲突;解除binlog dump线程和lock_log的冲突等等。

本文重点分析 第1,2个改进项,因为原来的模式的确会影响系统的tps,新的异步模式可以提高半同步模式下的系统事务处理能力。

二 优化

1、支持发送binlog和接受ack的异步化

通过前面的介绍,我们知道Semisynchronous Replication模式下,app在主库上提交一个事务/event,MySQL将每个事务写入binary并且同步到到slave ,master会等待至少一个slave通知:slave 已经接收到传过来的events并写入relay log,才返回给回话层 写入成功,或者直到传送日志发生超时,系统自动将为异步复制模式。

整体流程的逻辑图

MySQL 5.7增强版Semisync Replication性能优化(mysql 5.7 8.0)

5.5 版本semi sync 设计的缺点:

从原理以及上图来看,旧版本的semi sync 受限于dump thread ,原因是dump thread 承担了两份不同且又十分频繁的任务:传送binlog 给slave ,还需要等待slave反馈信息,而且这两个任务是串行的,dump thread 必须等待 slave 返回之后才会传送下一个 events 事务。dump thread 已然成为整个半同步提高性能的瓶颈在高并发业务场景下,这样的机制会影响数据库整体的TPS .

为了解决上述问题,在5.7.4版本的semi sync 框架中,独立出一个 ack collector thread ,专门用于接收slave 的反馈信息。这样master 上有两个进程独立工作,可以同时发送binlog 到slave ,和接收slave的反馈。整体流程的逻辑图

大体的实现思路是:

备库IO线程使用TCP协议和主库交互,读写socket可以同时进行,在开启主库semisync时,启动一个后台线程,使用select监听备库连接socket;dump线程不再等待备库ACK;在ack reciver线程等待ACK时,dump线程还能继续发送下一组group commit的binlog,进而提升TPS.

2 支持在事务commit前等待ACK;

新版本的semi sync 增加了rpl_semi_sync_master_wait_point参数 来控制半同步模式下 主库在返回给会话事务成功之前提交事务的方式。

该参数有两个值:

AFTER_SYNC (默认值):master 将每个事务写入binlog ,传递到slave,并且刷新到磁盘。master等待slave 反馈接收到事务并刷新到磁盘。一旦接到slave反馈,master在主库提交事务并且返回结果给会话。 在AFTER_SYNC模式下,所有的客户端在同一时刻查看已经提交的数据。假如发生主库crash,所有在主库上已经提交的事务已经同步到slave并记录到relay log。此时切换到从库,可以保障最小的数据损失。

AFTER_COMMIT: master 将每个事务写入binlog ,传递到slave 刷新到磁盘(relay log),然后在主库提交事务。master在提交事务后等待slave 反馈接收到事务并刷新到磁盘。一旦接到slave反馈,master将结果反馈给客户端。在AFTER_COMMIT模式下,如果slave 没有应用日志,此时master crash,系统failover到slave,app将发现数据出现不一致,在master提交而slave 没有应用。

MySQL Semisynchronous Replication介绍 前言MySQL5.5版本之前默认的复制是异步(Asynchronous)模式的,MySQL5.5以plugins的方式提供了SemisynchronousReplication模式。在介绍semisync之前,我们先了解:半同步Asyn

MySQL中InnoDB的Memcached插件的使用教程 安装为了让文章更具完整性,我们选择从源代码安装MySQL,需要注意的是早期的版本有内存泄漏,所以推荐安装最新的稳定版,截至本文发稿时为止,最

探究MySQL中varchar的定义长度 UTF8字符集下:SQLcreatetabletest(idintauto_increment,namevarchar(),primarykey(id));SQLinsertintotestvalues(null,'');QueryOK,1rowaffected(0.sec)SQLinsertintotestvalues(null,'一二

标签: mysql 5.7 8.0

本文链接地址:https://www.jiuchutong.com/biancheng/347687.html 转载请保留说明!

上一篇:MySQL order by性能优化方法实例(mysql order by 性能)

下一篇:MySQL Semisynchronous Replication介绍

  • 进口关税和增值税可以抵扣吗
  • 土地增值税怎么计算
  • 广东通用机打发票可以抵扣吗
  • 出口货物退免税管理办法
  • 库存商品在贷方怎么调整
  • 固定资产直接计入成本的规定
  • 小微企业所得税优惠政策最新2022
  • 汇算清缴后发生销售退回会计分录
  • 非货币资产交换的会计处理原则
  • 股份支付费用的会计处理怎么做?
  • 承包费会计处理
  • 航空货运单可以由谁来填写
  • 购买股票如果公司亏损
  • 其他业务收入需要结转成本吗
  • 转让土地使用权 简易征收
  • 非盈利组织一般纳税人应交的税
  • 价外费用如何开普票
  • 转让土地使用权需要缴纳什么税
  • 绩效奖金是否属于工资判决书
  • 股权转让怎么交个人所得税
  • 房地产企业已预缴增值税如何抵扣
  • 固定资产应怎么做账
  • 企业转让股票交什么税费呢
  • uniqpp
  • mac屏幕横过来了
  • PHP:mb_strrpos()的用法_mbstring函数
  • 如何预防电脑系统崩溃
  • php生成php文件
  • 集体租赁住房有房产证吗
  • 在建工程账务处理管理制度
  • 博德明高沼上布朗威利山麓的废弃小屋,英格兰 (© Helen Hotson/Alamy Stock Photo)
  • 前端项目如何部署到服务器
  • framework教程
  • laravel5.2实现区分前后台用户登录的方法
  • 应交税金及附加包括哪些
  • 尚品汇在哪
  • python怎样学
  • vue父子组件如何传递数据
  • php curl_setopt
  • 进项税额销项税额
  • 社保局申报工伤款多久能下
  • 发票管理办法是法律吗
  • 应税货物销售额含税吗
  • 企业分红所得需要缴纳企业所得税吗
  • sql 按,拆分成多条数据
  • 分红是怎么分的?
  • 融资租入固定资产的租赁费属于什么费用
  • 外币业务的会计分录
  • 个体工商户不经营需要税务登记吗
  • 一般纳税人销售旧货
  • 铁路运费印花税怎么算
  • 实收资本印花税税率多少
  • 收到现金怎么做凭证
  • 什么是长期的
  • 辅助核算设置后使用后还可以随时修改
  • 报关金额多报了900美金怎么办
  • 商业折扣的会计分录
  • centos下安装jdk
  • fedora32
  • 微软平板电脑surface pro2参数
  • Win10预览版怎么变回正式版
  • winxp共享文件
  • ubuntu20.04快捷键
  • centos6.5双网卡绑定
  • 如何在win7电脑上添加新的打印机
  • linux中vi命令是什么意思
  • 服务器自动关机什么原因
  • unityai寻路
  • 前端面试题及答案2023vue3
  • node.js开发实战详解
  • 编写批处理运行程序
  • python中str的用法
  • js 获取图片大小
  • 关于中秋节的古诗
  • java教程 视
  • jquery中选择器分为哪三种
  • 河南省城镇土地使用税优惠政策2020
  • 公司自有房屋装修费用入什么料目
  • 已代扣代缴个人所得税,他人还需要缴纳个人所得税吗?
  • 新疆喀什泽普县教育局联系电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设