博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mysql-InnoDB 事物学习
阅读量:6079 次
发布时间:2019-06-20

本文共 1566 字,大约阅读时间需要 5 分钟。

事物基本概念

事物的特性(ACID)

原子性 atomicity

一致性 consistency

隔离性 isolation

持久性 durability

事物的类型

扁平事物

带有保存点的扁平事物

链事物 嵌套事务

分布式事务

事物的实现

redo与undo redo

redo:保证事物的原子性、持久性,物理日志,基本上是顺序写
undo:保证事物的一致性,逻辑日志,undo会产生redo,用于事物回滚和mvcc,随机读写

redo

redo log buffer

redo log file

force log at commit机制实现事物的持久性

redo log buffer -> 文件系统缓存 -> (fsync) 磁盘文件

innodb_flush_log_at_trx_commit

0:master thread完成写入磁盘
1:默认,每次事物提交必须fsync
2:写入文件系统缓存,不执行fsync

log block

512 字节和磁盘山区大小一致,保证日志写入是原子性的,不需要doublewrite ?技术

clipboard.png

分为 512 - 12 -8 = 492

重做日志头:12 字节
重做日志内容:
重做日志尾:8字节

LOG_BLOCK_HAR_NO【4字节】:log block在 log buffer的位置

LOG_BLOCK_HAR_DATA_LEN【2字节】:log block占用大小
LOG_BLOCK_FIRST_REC_GROUP【2字节】:第一个日志所在的偏移量
LOG_BLOCK_CHECKPOINT_NO【4字节】:最后被写入时的检查点第4字节的值 ??

log grooup

多个多个重做日志文件组成

redo log file

clipboard.png

clipboard.png

重做日志格式

clipboard.png

redo_log_type:重做日志的类型

space:表空间的ID
page_no:页的偏移量

LSN(log sequence number)

8字节,单调递增

含义:
重做日志写入总量
checkpoint的位置
页的版本

clipboard.png

undo

undo segment:共享表空间内

(128个)rollback segment > (1024个)undo segment ,事物并发限制在128*1024

undo log 格式

insert undo log

update undo log

clipboard.png

purge

group commit

事物的隔离级别

READ UNCOMMIT:使用查询语句不会加锁,可能会读到未提交的行(Dirty Read)

READ COMMIT:只对记录加记录锁,而不会在记录之间加间隙锁,所以允许新的记录插入到被锁定记录的附近,所以再多次使用查询语句时,可能得到不同的结果(Non-Repeatable Read)EPEATABLE READ:多次读取同一范围的数据会返回第一次查询的快照,不会返回不同的数据行,但是可能发生幻读(Phantom Read);
SERIALIZABLE:InnoDB 隐式地将全部的查询语句加上共享锁,解决了幻读的问题;

脏读:在一个事务中,读取了其他事务未提交的数据

不可重复读:在一个事务中,同一行记录被访问了两次却得到了不同的结果。
幻读:在一个事务中,同一个范围内的记录被读取时,其他事务向这个范围添加了新的记录。

不可重复读的原因就是,在 READ COMMITED 的隔离级别下,存储引擎不会在查询记录时添加行锁,锁定 id = 3 这条记录。

分布式事物

XA

Resource Managers:提供访问事物资源的方法

Transaction Maneger:协调参与全局事物中的各个事物
Application Program:定义事物的便捷,指定全局事物中的操作

clipboard.png

转载地址:http://crhgx.baihongyu.com/

你可能感兴趣的文章
(转载)从 Java 代码到 Java 堆
查看>>
模仿pgpool-II的方式,建立线程池
查看>>
根据旋转前后的向量值求旋转矩阵
查看>>
微软开放Kinect for Windows样本代码
查看>>
武汉户口的必要性
查看>>
计算机语言的基本理论
查看>>
[转]java加密算法简要介绍
查看>>
aaa
查看>>
批处理命令篇--配置免安装mysql
查看>>
VMWare虚拟机系统网络配置
查看>>
性能优化你必须知道的那些事儿
查看>>
锋利的jQuery-4--给事件添加命名空间
查看>>
linux概念之cpu分析
查看>>
性能调优攻略
查看>>
Java策略模式(Strategy模式) 之体验
查看>>
负载均衡探测器lbd
查看>>
【转】浅谈.net remoting 与webservice
查看>>
Golang 笔记 5 go语句
查看>>
ef core
查看>>
JavaScript——DOM或以树形展示的Web页面
查看>>