mysql 事务 隔离性 锁
1、四大特性
1.1 原子性(Atomicity)
一个事务是不可分割的最小工作单位。一个事务是不可分割的最小工作单位。
利用undo log保证原子性,undo log记录的是操作的反向语句,例如执行的insert语句,则undo log记录的是delete语句。
1.2 一致性(Consistency):
事务执行前后的数据,必须保持一致。
利用redo log保证持久性,需要注意redo log和binlog的一致性。为了保证一致性,mysql的内部存在XA事务,俗称日志的两阶段提交协议。
redo log 记录的是数据的物理变化,所以叫物理日志,当我们修改数据的时候,写完内存了,但数据还没真正写到磁盘的时候。此时我们的数据库挂了,我们可以根据redo log来对数据进行恢复!
binlog 记录的是数据的逻辑变化,所以又叫逻辑日志,statement模式下记载的是update/delete/insert这样的SQL语句,主要用来主从复制和恢复数据用
XA事务:将事务提交分为了两个阶段,prepare阶段和commit阶段
prepare:写入redo log,并将回滚段置为prepared状态,此时binlog不做操作
commit:innodb释放锁,释放回滚段,设置提交状态,写入binlog,然后存储引擎层提交。
mysql数据库崩溃恢复:
崩溃恢复时,扫描最后一个Binlog文件,提取其中的xid;
InnoDB维持了状态为Prepare的事务链表,将这些事务的xid和binlog中记录的xid做比较,如果在binlog中存在,则提交,否则回滚事务。
1.3 隔离性(Isolation):
多个事务之间数据要相互隔离,即彼此独立和透明互不影响。
利用锁和MVCC机制保证隔离性
隔离级别分为:读未提交、读已提交、可重复读、串行化
四种隔离级别主要是为了解决:脏读、不可重复读、幻读等情况
详细说明见 4
1.4 持久性(Durability):
事务一旦被提交(commit / rollback ),数据的改变是永久性的。
2、大事务
执行时间很长的事务,会造成大量的阻塞和锁超时,容易造成主从延迟,回滚费劲等
监控:监控表 information_schema.Innodb_trx ,设置长时间阈值,超过了报警或者kill
select * from information_schema.innodb_trx where TIME_TO_SEC(timediff(now(),trx_started))>60;
3、数据库宕机重启,事务丢失
主要sync_binlog配置(控制binlog刷盘时机)和innodb_flush_log_at_trx_commit配置(配置redolog刷盘时机)
默认innodb_flush_log_at_trx_commit=1 sync_binlog=0 :每次事务提交时都将 redo log 直接持久化到磁盘.但是MySQL不控制binlog的刷新,由操作系统自己控制它的缓存的刷新
4、隔离性
隔离级别:读未提交、读已提交、可重复读、串行化
解决问题:脏读、不可重复读、幻读
名词解释
脏读:某个事务执行时,读到了其他事务还没commit的数据,其他事务进行了回滚操作,就造成了脏读,也就是读到了脏数据
不可重复读:某事务执行时,事务执行过程中任意两个时间点读取同一数据时结果不同,原因是读取某一个数据后,其他事务进行了update、commit操作,此时再读数据就出现了内容不一致情况。主要出现在update上
幻读:a按某个规则读取记录后,b事务执行了insert语句,a再查询的时候就会发现相同规则出来的数据有变化,主要出现在insert上
读未提交:mysql的最低隔离级别,相当于什么措施都没有
读已提交:只能读取其他事务提交的数据,解决了脏读,但是不能解决不可重复读
可重复读:mysql的默认隔离级别
串行化:最高级别的隔离,所有的事务顺序执行,隔离效果最好,性能最差
读已提交和可重复读分别是用行锁、间隙锁和MVCC机制实现的。
5、锁
只有在inner DB下才会存在锁的概念
范围锁
表锁:直接锁定一个表、其余所有对表的操作都被阻塞,一般用在DDL处理时(insert,alter、drop)
行锁:冻结一行或者几行,比如where name ='张三',则锁定所有name=张三的行
其他锁
共享锁:S锁,加了S锁之后可以允许其他事务读该记录
排他锁:X锁,加了X锁之后不允许其他事务读该记录
记录锁:仅锁定单挑索引记录的数据
间隙锁:冻结一个索引区间,比如where id in (1,4,6,8),那么会冻结1-4行 5-8行两个区间,左开右闭
意向锁:可以与表锁或者行锁共用,比如某事务给某一行加了一个排他锁,会同时给表添加一个意向锁,那么事务2读该表时就可以不用每条记录的判断是否有锁,而是可以直接通过意向锁知道锁的位置。
mysql 事务 隔离性 锁的更多相关文章
- 跟面试官侃半小时MySQL事务隔离性,从基本概念深入到实现
提到MySQL的事务,我相信对MySQL有了解的同学都能聊上几句,无论是面试求职,还是日常开发,MySQL的事务都跟我们息息相关. 而事务的ACID(即原子性Atomicity.一致性Consiste ...
- 19.10.11学习日记随笔 mysql事务隔离性
一天的感悟 学习事务的处理方式,其中反想自己学过的flask 默认是开启事务的,flask_sqlalchemy每次在提交时都是需要commit,或者失败是需要rollback回滚操作的,其实pyth ...
- MySQL事务及事务隔离级别 锁机制
什么是事务? 当多个用户访问同一份数据时,一个用户在更改数据的过程中可能有其他用户同时发起更改请求,为保证数据库记录的更新从一个一致性状态更改为另一个一致性状态,这样的操作过程就是事务.事务具有的AC ...
- 理解MySQL数据库事务-隔离性
Transaction事务是指一个逻辑单元,执行一系列操作的SQL语句. 事务中一组的SQL语句,要么全部执行,要么全部回退.在Oracle数据库中有个名字,叫做transaction ID 在关系型 ...
- Mysql事务-隔离级别
MYSQL事务-隔离级别 事务是什么? 事务简言之就是一组SQL执行要么全部成功,要么全部失败.MYSQL的事务在存储引擎层实现. 事务都有ACID特性: 原子性(Atomicity):一个事务必须被 ...
- MySQL事务隔离级别(二)
搞清楚MySQL事务隔离级别 首先创建一个表 account.创建表的过程略过(由于 InnoDB 存储引擎支持事务,所以将表的存储引擎设置为 InnoDB).表的结构如下: 为了说明问题,我们打开两 ...
- MySQL事务隔离级别(一)
本文实验的测试环境:Windows 10+cmd+MySQL5.6.36+InnoDB 一.事务的基本要素(ACID) 1.原子性(Atomicity):事务开始后所有操作,要么全部做完,要么全部不做 ...
- Mysql 事务隔离级别分析
Mysql默认事务隔离级别是:REPEATABLE-READ --查询当前会话事务隔离级别mysql> select @@tx_isolation; +-----------------+ | ...
- 一文讲清楚MySQL事务隔离级别和实现原理,开发人员必备知识点
经常提到数据库的事务,那你知道数据库还有事务隔离的说法吗,事务隔离还有隔离级别,那什么是事务隔离,隔离级别又是什么呢?本文就帮大家梳理一下. MySQL 事务 本文所说的 MySQL 事务都是指在 I ...
随机推荐
- 【Java】IO
文章目录 IO 说明 流的分类 关于相对路径 节点流 FileRead 对read()操作升级:使用read的重载方法 总结 FileWriter 复制操作 总结 FileInput(Output)S ...
- 【PTA】5-1 输入一个正整数n,再输入n个学生的姓名和百分制成绩,将其转换为两级制成绩后输出。
5-1 输入一个正整数n,再输入n个学生的姓名和百分制成绩,将其转换为两级制成绩后输出.要求定义和调用函数set_grade(stu, n),其功能是根据结构数组stu中存放的学生的百分制成绩scor ...
- 【Java】方法
文章目录 何谓方法 方法的定义 方法调用 方法重载 命令行传参 可变参数 递归 何谓方法 System.out.println(),是什么 Java方法是语句的集合,它们在一起执行一个功能 方法是解决 ...
- 自旋锁-JUC系列
公众号原文:自旋锁-JUC系列 前言 2022!这个年份现在看起来都觉得有那么些恍惚的未来感,然而现在已在脚下. 无边落木萧萧下, 不尽长江滚滚来! 人生如白驹过隙! 本来计划最近把AQS源码分析做了 ...
- win+ r 命令
Win 键+R calc:计算器 notepad:记事本 mspaint:画图 cmd:控制台 control:控制面板 desk.cpl:打开控制面板中的桌面设置 main.cpl:鼠标设置 ine ...
- azure django bug
azure web app service azure web app service无法部署dhango网站 本地服务器测试代码 实际azure测试 django service 没有部署选项,需要 ...
- 【必杀】为应用程序池“XXX”提供服务的进程在与 Windows Process Activation Service 通信时出现严重错误。该进程 ID 为“XXXX”。数据字段包含错误号。
之前写过一篇文章,https://www.cnblogs.com/qidian10/p/6028784.html 解释如何解决此类问题,但现在回过头来想一下,之前的文章还是太过浅显,无法完全有效的彻底 ...
- 学习鸟哥私房菜--linux bash 的环境变量ps1设置
bash里边的变量ps1是用户平时的提示符,系统默认为[username@host 工作目录]$.关于ps1的相关介绍详见:http://www.cnblogs.com/starspace/archi ...
- Nginx全面介绍 什么是Nginx?
目录 一:Nginx全面讲解 1.简介: 2.nginx的用武之地 3.关于代理(解析含义作用) 二:正向代理 三:反向代理 四:项目应用场景 五:正向代理与反向代理区别 1.正向代理 2.反向代理 ...
- 『无为则无心』Python基础 — 41、Python中文件的读写操作(一)
目录 1.文件操作步骤 2.文件的读写操作 (1)文件的打开 (2)打开文件模式 (3)获取一个文件对象 (4)关于文件路径 1.文件操作步骤 当我们要读取或者写入文件时,我们需要打开文件,在操作完毕 ...