返回顶部
首页 > 资讯 > 数据库 >MySQL中AFTER_SYNC/AFTER_COMMIT的过程分析
  • 424
分享到

MySQL中AFTER_SYNC/AFTER_COMMIT的过程分析

2024-04-02 19:04:59 424人浏览 八月长安
摘要

本篇内容主要讲解“Mysql中AFTER_SYNC/AFTER_COMMIT的过程分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql中AFTER_SY

本篇内容主要讲解“Mysql中AFTER_SYNC/AFTER_COMMIT的过程分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习mysql中AFTER_SYNC/AFTER_COMMIT的过程分析”吧!

Mysql 5.7增强了半同步复制,rpl_semi_sync_master_wait_point增加了AFTER_SYNC的值,由该参数AFTER_SYNC/AFTER_COMMIT两个值选择是否启用增强半同步.
mysql> SET rpl_semi_sync_master_wait_point= AFTER_SYNC;  开启了mysql 5.7增强半同步,5.7默认就是开启的;
mysql> SET rpl_semi_sync_master_wait_point= AFTER_COMMIT;   5.6的半同步方式;           
当半同步模式为 AFTER_COMMIT时:
过程分析如下:
        1 > session 发出commit请求
        2 > flush binlog and fsync binlog
        3 > InnoDB 引擎层 commit 
        4 > 发送binlog到SLAVE,等待slave发送ack确认
        5 > slave 接受binlog 写入relay log ,刷盘完成发送ack确认包给master
        6 > master 返回 commit ok 信息给session
        
        另外 (master 等待事务A 的 ACK的时候宕机,此时新事务B在宕机之前开启):
        1> binlog 未发送到从库:
            事务B获取到事务A提交的内容, 此时宕机故障切换到slave,事务B获取到的内容却丢失了。事务A commit没有收到反馈信息(则需要业务判断了)。
        2> binlog 已经发送给从库 :
            事务B获取到事务A提交的内容,故障切换到salve ,B仍然获取到A提交的内容,没毛病。事务A commit没有收到反馈信息,若重新执行该事务,则相当于执行两次A事务(则需要业务判断了)。
MySQL中AFTER_SYNC/AFTER_COMMIT的过程分析

当半同步模式为 AFTER_SYNC(5.7版本推荐使用)时:
过程分析如下:
           1 > session 发出commit请求
           2 > flush binlog and fsync binlog
           3 > 发送binlog到SLAVE,等待slave发送ack确认
           4 > slave 接受binlog 写入relay log ,刷盘完成发送ack确认包给master
           5 > InnoDB 引擎层 commit 
           6 > master 返回 commit ok 信息给session


           另外(master 等待事务A 的 ACK的时候宕机,此时新事务B在宕机之前开启):
           1> 事务B读取不到事务A的内容,因为事务A的ENGINE层还没有提交(无损复制)
MySQL中AFTER_SYNC/AFTER_COMMIT的过程分析
dump thread过程分析:
 mysql5.6版本之前:
        1> master dump thread 发送binlog events 给 slave 的IO thread,等待 slave 的ack回包
        2> slave 接受binlog events 写入redo log ,返回 ack 包给master dump thread
        3> master dump thread 收到ack包 ,给session返回commit ok,然后继续发送写一个事务的binlog。

mysql5.7之后新增ack线程
        1> master dump thread 发送binlog events 给 slave 的IO thread,开启ack线程等待 slave 的ack回包,dump 线程继续向slaveIO thread发送下一个事务的binlog。
        2> slave 接受binlog events 写入redo log ,返回 ack 包给master ack线程,然后给session返回commit ok。


过程总结:
Master在收到slave的应答后才Commit事务--after_sync(5.6上Master在commit后,才等待Slave的应答--after commit).
因此在确认事务复制到Slave上之前,并发的事务看不到当前事务的数据.
当Master出现故障时,所有已经提交的事务都复制到了Slave上.
缺省采用无数据丢失的应答等待机制after_sync。用户也可以选择使用5.6的应答等待机制after_commit

设置方法:
mysql> SET rpl_semi_sync_master_wait_point= AFTER_SYNC;

Master接收到N个slave的应答后,才commit 事务.
用户可以设置应答Slave的数量:
mysql> SET GLOBAL rpl_semi_sync_master_wait_for_slave_count= N;

到此,相信大家对“MySQL中AFTER_SYNC/AFTER_COMMIT的过程分析”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中AFTER_SYNC/AFTER_COMMIT的过程分析

本文链接: https://lsjlt.com/news/65305.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL中AFTER_SYNC/AFTER_COMMIT的过程分析
    本篇内容主要讲解“MySQL中AFTER_SYNC/AFTER_COMMIT的过程分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL中AFTER_SY...
    99+
    2024-04-02
  • MySQL 5.7中sync_binlog参数和半同步中after_commit和after_sync的区别有哪些
    这篇文章给大家分享的是有关MySQL 5.7中sync_binlog参数和半同步中after_commit和after_sync的区别有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来...
    99+
    2024-04-02
  • MySQL中Bug发现过程分析
    本篇内容介绍了“MySQL中Bug发现过程分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!使用的是PXC...
    99+
    2024-04-02
  • MySQL的查询过程分析
    关系型数据库管理系统查询处理一般分为4个阶段: 见下图 怎么验证这几个阶段对应在MySQL的关系呢? 这里实验的数据库版本:5.6.16-64.2-56 OS:CentOS release 6.5 Ker...
    99+
    2024-04-02
  • mysql中存储过程的示例分析
    这篇文章主要介绍了mysql中存储过程的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在mysql中,存储过程是一组为了完成特定功能...
    99+
    2024-04-02
  • mysql存储过程的案例分析
    这篇文章主要介绍mysql存储过程的案例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、什么是存储过程为以后的使用而保存的一条或多条MySQL语句的集合。存储过程思想上就是数据...
    99+
    2024-04-02
  • MySQL的存储过程实例分析
    今天小编给大家分享一下MySQL的存储过程实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一...
    99+
    2024-04-02
  • MYSQL中存储过程与函数的示例分析
    这篇文章主要介绍了MYSQL中存储过程与函数的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。  一、模式  二、存储过程与存储函数 ...
    99+
    2024-04-02
  • PostgreSQL中vacuum过程分析
    本篇内容主要讲解“PostgreSQL中vacuum过程分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PostgreSQL中vacuum过程分析”吧!一、数...
    99+
    2024-04-02
  • MYSQL 连接登录过程分析
      MYSQL 连接登录过程分析 在较新MYSQL版本中,默认没有开启线程池的功能,每个客户连接在服务器进程中都拥有自己的线程。 当客户端(应用)连接到M...
    99+
    2024-04-02
  • mysql存储过程举例分析
    这篇文章主要讲解了“mysql存储过程举例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql存储过程举例分析”吧!(1).格式MySQL存储过程创...
    99+
    2024-04-02
  • MySQL 崩溃恢复过程分析
    天有不测风云,数据库有旦夕祸福。 前面写 Redo 日志的文章介绍过,数据库正常运行时,Redo 日志就是个累赘。 现在,终于到了 Redo 日志扬眉吐气,大显身手的时候了。 本文我们一起来看看,My...
    99+
    2023-09-16
    mysql 数据库 php java 程序员
  • MySQL 存储过程的优缺点分析
    MySQL 5.0 版本开始支持存储过程。存储过程(Stored Procedure)是数据库中存储的复杂程序,以便外部应用调用的一种数据库对象。存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中...
    99+
    2022-05-21
    MySQL 存储过程 MySQL 存储过程优缺点
  • MySQL中存储过程和存储函数的示例分析
    这篇文章主要为大家展示了“MySQL中存储过程和存储函数的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL中存储过程和存储函数的示例分析”这篇文...
    99+
    2024-04-02
  • MySQL存储过程与函数的案例分析
    这篇文章将为大家详细讲解有关MySQL存储过程与函数的案例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。        &nb...
    99+
    2024-04-02
  • MySQL慢日志优化的案例分析过程
    这期内容当中小编将会给大家带来有关MySQL慢日志优化的案例分析过程,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。最近在分析一个问题的时候,...
    99+
    2024-04-02
  • mysql存储过程用法实例分析
    本文实例讲述了mysql存储过程用法。分享给大家供大家参考,具体如下: 概述: 简单的说,就是一组SQL语句集,功能强大,可以实现一些比较复杂的逻辑功能,类似于JAVA语言中的方法; 存储过程跟触发器有点类...
    99+
    2024-04-02
  • PostgreSQL的vacuum过程中heap_vacuum_rel函数分析
    这篇文章主要介绍“PostgreSQL的vacuum过程中heap_vacuum_rel函数分析”,在日常操作中,相信很多人在PostgreSQL的vacuum过程中heap_vacuum_rel函数分析问...
    99+
    2024-04-02
  • WebSocket中通信过程的示例分析
    小编给大家分享一下WebSocket中通信过程的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么是 WebSocket...
    99+
    2024-04-02
  • Angularjs中启动过程的示例分析
    这篇文章主要介绍Angularjs中启动过程的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!启动过程(v1.3.9)步骤一用自执行函数的形式让整个代码在加载完成之后立即执行i...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作