Mysql性能调优与架构设计-9

InnoDB引擎底层

三大特性

  • 双写机制
  • Buffer Pool
  • 自适应Hash索引

行格式

  • COMPACT
  • Redundant
  • Dynamic
  • Compressed

表空间

抽象概念

独立表空间
系统表空间

双写缓冲区(doublewrite buffer),在InnoDB写入数据文件之前,会往2个缓冲区写入,当双写完成后,数据才会写入适当的位置。
即InnoDB写数据的时候会进行两次磁盘IO,第一次就是双写缓冲区,因为磁盘内存空间是连续的,速度很快;第二次就是写数据。
InnoDB数据字典

Buffer Pool

服务器启动,申请一个连续的内存空间,
free链表:用于页分配缓存空间
flush链表:用于存储脏页,批量刷新磁盘

缓存淘汰机制
LRU链表管理

预读

  • 线性读取
  • 随机预读

全表扫描
划分区域的LRU链表,young区域和old区域(和JVM相反)

事务底层

  • 显式事务
  • 隐式事务(默认)

Mysql事务实现机制WAL(write ahead logging)

  • redo log 确保事务的持久性
  • undo log 确保事务的原子性
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值