MySQL社区

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 2340|回复: 5
打印 上一主题 下一主题

InnoDB master thread工作原理

[复制链接]
跳转到指定楼层
1#
发表于 2014-12-9 09:54:26 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我们简单交流下InnoDB master thread学习,有兴趣的朋友可以参考<<MySQL技术内蒙--InnoDB存储引擎第二版>>
void master_thread(){    goto loop;loop:for (int i=0;i<10;i++){    thread_sleep(1) //sleep 1 second-->每秒执行操作(负载在情况下会延迟)    do log buffer flush to disk  //重做日志缓冲刷新到磁盘,即使这个事务没有提交(总是)    if ( last_ten_second_ios < 5% innodb_io_capacity) //如果当前的10次数小于(5% * 200=10)(innodb_io_capacity默认值是200)        do merger 5% innodb_io_capacity insert buffer //执行10个合并插入缓冲的操作(5% * 200=10)    if ( buf_get_modified_ratio_pct > innodb_max_dirty_pages_pct ) //如果缓冲池中的脏页比例大于innodb_max_dirty_pages_pct(默认是75时)        do buffer pool plush 100% innodb_io_capacity dirty page //刷新200个脏页到磁盘    else if enable adaptive flush  //如果开户了自适应刷新        do buffer pool flush desired amount dirty page //通过判断产生redo log的速度决定最合适的刷新脏页的数量    if ( no user activity ) //如果当前没有用户活动        goto backgroud loop  //跳到后台循环}

完整的说明,请看:http://www.cnblogs.com/xuanzhi201111/p/4040681.html
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享淘帖 顶 踩
推荐
 楼主| 发表于 2014-12-9 17:47:45 | 只看该作者
kider 发表于 2014-12-9 14:56
乱了...
另外整片转发比较好。

http://www.cnblogs.com/xuanzhi201111/p/4040681.html这个完整的,也是我博客{:soso_e113:}

点评

你的博客写的很好!  发表于 2014-12-10 09:36
2#
发表于 2014-12-9 14:56:56 | 只看该作者
乱了...
另外整片转发比较好。
4#
 楼主| 发表于 2014-12-12 15:36:24 | 只看该作者
kider 发表于 2014-12-9 14:56
乱了...
另外整片转发比较好。

我发表出来的东西,找不到地方修改,好纠结

点评

修改自己的帖子,发表后超过一定时候后,就不能修改了。 看来论坛需要把这时间调整大点估计较好。  发表于 2015-1-4 10:20
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|申请友链|小黑屋|Archiver|手机版|MySQL社区 ( 京ICP备07012489号   
联系人:周生; 联系电话:13911732319

GMT+8, 2024-4-28 12:19 , Processed in 0.072377 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表