百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> 介绍 Mysql-InnoDB 事物学习
分享文章到:

介绍 Mysql-InnoDB 事物学习

发布时间:01/01 来源:未知 浏览: 关键词:
mysql视频教程栏目介绍InnoDB的事物学习

引荐(免费):mysql视频教程

事物根本概念

事物的特性(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 ?技术

f8142a60088bd3dd2261a288a6ddbec.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

90a922da90765bc084f28a3d8b2a2f1.png

重做日志格局

d0cf70ec8ad98875ce6019487a10e37.png

redo_log_type:重做日志的类型
space:表空间的ID
page_no:页的偏移量

LSN(log sequence number)

8字节,单调递增
含义:
重做日志写入总量
checkpoint的位置
页的版本

e11856a986b773eb35510cec02350a5.png

undo

undo segment:同享表空间内

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

undo log 格局

insert undo log
update undo log

fed29bc0daadcc4d3c58f1dfe1b461e.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:定义事物的便利,指定全局事物中的操纵

037b7239cf5d5358493ff8a63fb4056.png

以上就是介绍 Mysql-InnoDB 事物学习的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有152人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板