Innodb存储引擎--落盘整理

MySQL体系架构图

MySQL体系架构

Innodb体系架构

innodb的体系架构

MySQL主要就是信息的持久化存储,持久化就必须落盘,本篇文章
将整理介绍MySQL最重要的三个文件的落盘操作

Redo log 落盘

WAL(Write ahead redo log) 保障了事务的持久性,
必然,redo log的LSN > 数据(脏页和落盘)LSN
innodb_log_buffer_size 控制redo log缓冲池大小
何时缓冲池中的数据落盘

  • master thread 每一秒,不论事务是否提交
  • innodb_flush_log_at_trx_commit 控制每次事务提交时
    =0:不落盘,等master thread的刷新
    =1:fsync落盘,不丢失事务
    =2:OS缓冲写
innodb_flush_log_at_trx_commit示意图.png
  • 缓冲池剩余空间小于1/2时

redo log写盘是磁盘扇区单位写,不存在写失败的情况

Binlog 落盘

binlog 是mysql server的。与redo log无直接关系,且可以关闭
sync_binlog=[N]控制落盘的频次,通过innodb_support_xa 协同binlog和innodb的redo log处理

**总结:理清redo log 和 binlog的层次,作用:
redo log是innodb独立使用的,记录的是数据页的更改的物理情况
binlog是mysql的整个写入操作,记录的是mysql逻辑写操作
sync_binlog,innodb_flush_log_at_trx_commit,innodb_support_xa。三者都设置为1(TRUE),数据才能真正安全。sync_binlog非1,可能导致binlog丢失(OS挂掉),从而与innodb层面的数据不一致。innodb_flush_log_at_trx_commit非1,可能会导致innodb层面的数据丢失(OS挂掉),从而与binlog不一致。
**

data 落盘(数据页&索引页 )

改进的LRU算法,得出哪些脏页需要落盘

CheckPoint技术,实际的落盘操作

  • sharp point

数据库关闭时,刷盘,即innodb_fast_shutdown=1

  • fuzzy point

master thread 1s 和 10s
LRU 列表没有足够的空闲页
redo log 没有足够的可复用的空间时
对比redo log的LSN和落盘数据的LSN
脏页率 > innodb_max_dirty_pages_pct

数据写盘操作是double write,防止部分写失效

double write (顺序写ibdata,随机写ibd):
1、dirty pages memcpy到 double wirte buffer

2、doublewrite buffer 分两次fsync 1M数据到共享表空间的double buffer(顺序写,fsync可以避免写失效的问题)
3、doublewrite buffer 写入到ibd数据文件(离散写)

总结: redo log的落盘和data的落盘是独立的操作单元,尽管它们可能在master thread有同时操作概率,它们之间的唯一协调处理在fuzzy checkpoint的第三个场景:redo log复用空间不够了,导致了data落盘

Master Thread 工作流:

后台线程 relog 落盘 合并插入缓冲 刷脏页 purge undo段
master 1s low IO 脏页>pct
master 10s low IO OR 脏页>pct
backgroud
flush loop
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容