【mysql】主从同步,事务等概念
问题:
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】主从同步,事务等概念的更多相关文章
- Mysql主从同步(1) - 概念和原理介绍 以及 主从/主主模式 部署记录
Mysql复制概念Mysql内建的复制功能是构建大型高性能应用程序的基础, 将Mysql数据分布到多个系统上,这种分布机制是通过将Mysql某一台主机数据复制到其它主机(slaves)上,并重新执行一 ...
- 这次一定要教会你搭建Redis集群和MySQL主从同步(非Docker)
前言 一直都想自己动手搭建一个Redis集群和MySQL的主从同步,当然不是依靠Docker的一键部署(虽然现在企业开发用的最多的是这种方式),所以本文就算是一个教程类文章吧,但在动手搭建之前,会先聊 ...
- Mysql主从同步(复制)
目录: mysql主从同步定义 主从同步机制 配置主从同步 配置主服务器 配置从服务器 使用主从同步来备份 使用mysqldump来备份 备份原始文件 ...
- mysql主从同步+mycat读写分离+.NET程序连接mycat代理
背景 最近新项目需要用到mysql数据库,并且由于数据量大的原因,故打算采用1主1从(主数据库负责增.删.改操作:从数据库负责查操作)的数据库架构,在实现主从之后还要实现读写分离的代理,在网上搜寻了很 ...
- mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理
转自:http://www.cnblogs.com/kevingrace/p/6261091.html 在mysql工作中接触最多的就是mysql replication mysql在复制方面还是会有 ...
- mysql 主从同步 mysql代理服务器
搭建mysql主从同步(实现数据自动备份)实例:把主机192.168.4.100的数据库配置为主机192.168.4.99的从数据库 主数据库服务器配置修改配置文件: [root@mysql ~]# ...
- Mysql主从同步(复制)(转)
文章转自:https://www.cnblogs.com/kylinlin/p/5258719.html 目录: mysql主从同步定义 主从同步机制 配置主从同步 配置主服务器 配置从服务器 使用主 ...
- mysql主从同步(2)-问题梳理
之前详细介绍了Mysql主从复制的原理和部署过程,在mysql同步过程中会出现很多问题,导致数据同步异常.以下梳理了几种主从同步中可能存在的问题:1)slave运行过慢不能与master同步,也就是M ...
- 【实操笔记】MySQL主从同步功能实现
写在前边: 这两天来了个需求,配置部署两台服务器的MySQL数据同步,折腾了两天查了很多相关资料,一直连不上,后来发现其实是数据库授权的ip有问题,我们用的服务器是机房中的虚拟机加上反向代理出来的,坑 ...
- mysql系列之6.mysql主从同步
普通文件的数据同步 nfs: 网络文件共享 samba: 共享数据 定时任务或守护进程结合 rsync.scp inotify(sersync)+rsync 触发式实时数据同步 ftp数据同步 ssh ...
随机推荐
- delphi 调用 c++builder
delphi 调用 c++builder c++builder 调用delphi 混合调用,mix https://community.embarcadero.com/blogs/entry/mixi ...
- hdoj 1003 学习思路
基本解题思路:动态规划,不考虑穷举,分治. 根据网上,状态转移方程是:MaxSum[i] = Max{ MaxSum[i-1] + A[i], A[i]} 翻译公式:到当前位置i 时,最大子序列和为: ...
- centos 卸载mysql
1 删除Mysql yum remove mysql mysql-server mysql-libs mysql-server; find / -name mysql 将找到的相关东西delete掉 ...
- Java相关文章
servlet/filter/listener/interceptor区别与联系 web.xml配置详解 在Eclipse中使用JUnit4进行单元测试(初级篇) 单点登录原理与简单实现 spring ...
- Android DevArt3:SingleTask启动模式探究:首先从MainActivity启动案例入口AActivity,并在A中启动BActivity,从B启动CActivity, 再从C中又启动AActivity, 最后在A中启动B,现在按两次back键,然后回到的是哪个Activity? 答案是,回到MainActivity。
SingleTask启动模式探究 GitHub如题:首先从MainActivity启动案例入口AActivity,并在A中启动BActivity,从B启动CActivity,再从C中又启动AActiv ...
- linux下json工具jq
1.查看json文件 [root@VM-1-10-11 f46c19f56252a74a46fd30026001e62cc5ecadd04bc9a80c47f6fd5f9dc0586b]# pwd / ...
- canvas元素绘制太极图
<!DOCTYPE html><html><head> <title>canvas example</title> <meta cha ...
- linux编译安装php apache mysql (已试过)
阅读目录 (全部使用源码安装方式,先安装mysql,然后是apache,再是php,这样好像能防止挺多问题的,期间出现问题基本是依赖没有或者版本不对) 1.简介 2.安装apache 2.1.yum方 ...
- MySQL 5.7 使用原生JSON类型
首先回顾一下JSON的语法规则: 数据在键值对中, 数据由逗号分隔, 花括号保存对象, 方括号保存数组. 按照最简单的形式,可以用下面的JSON表示: {"NAME": " ...
- pip安装插件库
升级:python -m pip install --upgrade pip 读excel:pip install xlrd 写入excel:pip install xlwt