问题:

mysql用binary log来保证主从同步的可靠性和安全性,在mysql中,主从同步是异步线程和异步任务来保证的。

(在这点上,其它存储引擎有另外的选项,比如mongoDB和ElasticSearch的核心存储可以执行同步选项。mongoDB甚至支持同步到所有的从库后返回值,这样能够保证主从同步是没有延迟的。)

回到mysql,binary log是如何生成的?哪些操作会记录,哪些操作不会记录?

比如我有个疑问就是,对于事务操作,mysql是如何记录binary log的呢?

这个需要参考文档1:mysql在事务中的同步原理。

我来做个翻译:

先了解下,一个事务中可能包含transactional和nontransactional statement,这两个的区别是什么呢?

transactional statement是指,在事务处理失败,并执行rollback该事务时,该语句会自动回滚,这个是由mysql来保证的;

nontranscational statement是指,在事务处理失败,并执行rollback该事务时,该语句不会自动回滚,需要上层应用,即程序猿来保证。

mysql处理事务语句时遵循两条规则:

规则1:如果该事务的初始化语句是nontransactional语句,会立即写入到binlog中。其它事务语句会被cached。如果事务的结果是commit,那么在事务commit之后,这些cached语句会写入到binlog(之前是不写入的);但是如果事务回滚,有些cached语句仍然会被写入到binlog中,如果这些语句是nontransactional语句(因为这些语句是无法rollback的),其它会被抛弃;

规则2:基于statement的日志,nontransactional语句受系统参数影响(具体是:binlog_direct_non_transactional_updates)。如果该参数为OFF(默认值),日志是不会记录的。如果该参数为ON,nontransactional语句执行后会立即记入日志(而不仅仅是initial nontransactional语句)。其它语句会被保持在transaction缓存中,事务提交后记录日志。binlog_direct_non_transactional_updates对日志记录没有影响,在row-format(基于行)或者mixed-format(混合型日志)的binlog处理中。

我们来对mysql的语句做下区分:

Transactional语句:仅仅操作transactional tables的语句;

Nontransactional语句:仅仅操作nontransactional tables的语句;

Mixed语句:同时会操作nontransactional和transactional tables的语句;

在执行以下任一动作是,Mixed语句(更新一个transactional table)被认为是不安全的:

1,更新或读取临时表(temporary table);

2,读取untransactional table,并且事务的隔离级别是小于 DEPEATABLE_READ(the transaction isolation level is less than DEPEATABLE_READ);

一个事务中,如果一个mixed语句紧跟着要更新transactional table,并且它要执行以下任一操作时,被认为是不安全的:

1,更新任一tabe,and 从临时表中读取;

2,更新任一nontransactional table,并且binlog_direct_non_transactional_updates为OFF;

如果事务之间混合更新transactional 和 nontransactional表,binlog中的语句顺讯是正确的,并且所有已执行的语句被记录在binlog中,即使最后事务被rollback。

然而,如果第一个连接处理的transaction没有执行完毕,此时第二个连接更新的是nontransactional table,语句记录在binlog的顺序是非有序的。原因是,第二个连接执行的更新语句会在执行更新后立即写入到binlog中,而不管第一个连接的执行情况如何。

这里有我个人理解是,第一个连接在处理一个事务,现在进来一个新的连接(connection 2),connection2执行的语句是nontransactional 语句,此时有些观点会认为connection1的语句先记录在binlog中,connection2的语句后被记录在binlog中,但实际情况不是。

如果从库的引擎是nontransactional,主库的事务执行transactional和nontransactional表更新时应当要避免的,因为这会造成数据的不一样(具体指主库的transactional表和从库的nontransactional表)。

每一个事务都会被记录在binlog中,只要是以start开始,commit或者rollback结束。这个对于使用nontransactional存储引擎(比如MyISAM)的表操作语句也同样适用。

要了解什么样的table是transactional table,设么样的table是nontransactional table?参考文档2

参考文档1:https://dev.mysql.com/doc/refman/5.7/en/replication-features-transactions.html

文档2:https://dev.mysql.com/doc/refman/5.7/en/nontransactional-tables.html

【mysql】主从同步,事务等概念的更多相关文章

  1. Mysql主从同步(1) - 概念和原理介绍 以及 主从/主主模式 部署记录

    Mysql复制概念Mysql内建的复制功能是构建大型高性能应用程序的基础, 将Mysql数据分布到多个系统上,这种分布机制是通过将Mysql某一台主机数据复制到其它主机(slaves)上,并重新执行一 ...

  2. 这次一定要教会你搭建Redis集群和MySQL主从同步(非Docker)

    前言 一直都想自己动手搭建一个Redis集群和MySQL的主从同步,当然不是依靠Docker的一键部署(虽然现在企业开发用的最多的是这种方式),所以本文就算是一个教程类文章吧,但在动手搭建之前,会先聊 ...

  3. Mysql主从同步(复制)

    目录: mysql主从同步定义      主从同步机制 配置主从同步      配置主服务器      配置从服务器 使用主从同步来备份      使用mysqldump来备份      备份原始文件 ...

  4. mysql主从同步+mycat读写分离+.NET程序连接mycat代理

    背景 最近新项目需要用到mysql数据库,并且由于数据量大的原因,故打算采用1主1从(主数据库负责增.删.改操作:从数据库负责查操作)的数据库架构,在实现主从之后还要实现读写分离的代理,在网上搜寻了很 ...

  5. mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理

    转自:http://www.cnblogs.com/kevingrace/p/6261091.html 在mysql工作中接触最多的就是mysql replication mysql在复制方面还是会有 ...

  6. mysql 主从同步 mysql代理服务器

    搭建mysql主从同步(实现数据自动备份)实例:把主机192.168.4.100的数据库配置为主机192.168.4.99的从数据库 主数据库服务器配置修改配置文件: [root@mysql ~]# ...

  7. Mysql主从同步(复制)(转)

    文章转自:https://www.cnblogs.com/kylinlin/p/5258719.html 目录: mysql主从同步定义 主从同步机制 配置主从同步 配置主服务器 配置从服务器 使用主 ...

  8. mysql主从同步(2)-问题梳理

    之前详细介绍了Mysql主从复制的原理和部署过程,在mysql同步过程中会出现很多问题,导致数据同步异常.以下梳理了几种主从同步中可能存在的问题:1)slave运行过慢不能与master同步,也就是M ...

  9. 【实操笔记】MySQL主从同步功能实现

    写在前边: 这两天来了个需求,配置部署两台服务器的MySQL数据同步,折腾了两天查了很多相关资料,一直连不上,后来发现其实是数据库授权的ip有问题,我们用的服务器是机房中的虚拟机加上反向代理出来的,坑 ...

  10. mysql系列之6.mysql主从同步

    普通文件的数据同步 nfs: 网络文件共享 samba: 共享数据 定时任务或守护进程结合 rsync.scp inotify(sersync)+rsync 触发式实时数据同步 ftp数据同步 ssh ...

随机推荐

  1. screen 命令安装使用

    初次接触Linux的朋友总会有个感觉:Windows平台想同时运行多个操作,执行多个程序或命令只需要打开程序即可:但在Linux中,命令行就一个,要想同时执行多个命令如何操作? 其实,只需要一个简简单 ...

  2. PHP和Nginx 文件上传大小限制问题解决方法

    对于nginx+php的一些网站,上传文件大小会受到多个方面的限制,一个是nginx本身的限制,限制了客户端上传文件的大小,一个是php.ini文件中默认了多个地方的设置. 所以为了解决上传文件大小限 ...

  3. 机器学习进阶-案例实战-答题卡识别判 1.cv2.getPerspectiveTransform(获得投射变化后的H矩阵) 2.cv2.warpPerspective(H获得变化后的图像) 3.cv2.approxPolyDP(近似轮廓) 4.cv2.threshold(二值变化) 7.cv2.countNonezeros(非零像素点个数)6.cv2.bitwise_and(与判断)

    1.H = cv2.getPerspectiveTransform(rect, transform_axes) 获得投射变化后的H矩阵 参数说明:rect表示原始的位置左上,右上,右下,左下, tra ...

  4. 爬虫--requests模块学习

    requests模块 - 基于如下5点展开requests模块的学习 什么是requests模块 requests模块是python中原生的基于网络请求的模块,其主要作用是用来模拟浏览器发起请求.功能 ...

  5. World Cup 996B(排队模拟)

    题意:有n个通道,按顺序每一次站一个通道,直到所站的通道没有人 分析:模拟这个过程 #include<cstdio> int main() { ]; while(~scanf(" ...

  6. ACM__队列

    今天学回顾bfs的时候遇到了,遂总结一下 队列是一种特殊的线性表,只允许在队列的前端(front)进行删除操作,在队尾进行插入操作,进行插入操作的端称作队尾,进行删除操作的端称作对头.(来自百度百科) ...

  7. Servlet基本_サーブレットのライフサイクル、スレッドセーフ

    1.サーブレットのライフサイクル初期化時 ⇒ init() [初回リクエスト時] ↓リクエスト時 ⇒service() ⇒doGet() [Httpリクエストメソッドにより振り分け] 或は⇒doPos ...

  8. 102/107. Binary Tree Level Order Traversal/II

    原文题目: 102. Binary Tree Level Order Traversal 107. Binary Tree Level Order Traversal II 读题: 102. 层序遍历 ...

  9. js版MD5 (Message-Digest Algorithm)加密算法

    /**** MD5 (Message-Digest Algorithm)* http://www.webtoolkit.info/***/ var MD5 = function (string) { ...

  10. js字符串和控制语句

    1.js的字符串 * 字符串* 字符串是js数据类型中的一种*字符串拼接:+,加号有两层含义* 1.数学中的加法运算;* 2.字符串连接,当加号的任意一边是一个字符串,那就是字符串连接的意思; < ...