我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Mysql-InnoDB事物的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Mysql-InnoDB事物的示例分析

这篇文章给大家分享的是有关Mysql-InnoDB事物的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

事物基本概念

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

Mysql-InnoDB事物的示例分析

分为 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

Mysql-InnoDB事物的示例分析

重做日志格式

Mysql-InnoDB事物的示例分析

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

LSN(log sequence number)

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

Mysql-InnoDB事物的示例分析

undo

undo segment:共享表空间内

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

undo log 格式

insert undo log
update undo log

Mysql-InnoDB事物的示例分析

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:定义事物的便捷,指定全局事物中的操作

Mysql-InnoDB事物的示例分析

感谢各位的阅读!关于“Mysql-InnoDB事物的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Mysql-InnoDB事物的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql InnoDB存储引擎的示例分析

这篇文章主要介绍了mysql InnoDB存储引擎的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、概念InnoDB是MySQL默认的存储引擎,如果需要其不支持的特
2023-06-14

WCF事物操作的示例分析

这篇文章将为大家详细讲解有关WCF事物操作的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。指定了TransactionFlow(TransactionFlowOption.Mandatory),而
2023-06-17

mysql中InnoDB和MyISAM对比的示例分析

这篇文章主要介绍了mysql中InnoDB和MyISAM对比的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、事务:InnoDB 是事务型的,可以使用 Commit
2023-06-14

编程热搜

目录