MySQL社区
标题:
InnoDB master thread工作原理
[打印本页]
作者:
xuanzhi201111
时间:
2014-12-9 09:54
标题:
InnoDB master thread工作原理
我们简单交流下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
作者:
kider
时间:
2014-12-9 14:56
乱了...
另外整片转发比较好。
作者:
xuanzhi201111
时间:
2014-12-9 17:47
kider 发表于 2014-12-9 14:56
乱了...
另外整片转发比较好。
http://www.cnblogs.com/xuanzhi201111/p/4040681.html这个完整的,也是我博客{:soso_e113:}
作者:
xuanzhi201111
时间:
2014-12-12 15:36
kider 发表于 2014-12-9 14:56
乱了...
另外整片转发比较好。
我发表出来的东西,找不到地方修改,好纠结
欢迎光临 MySQL社区 (http://www.mysqlpub.com/)
Powered by Discuz! X3.2