我们致力于一个MySQL知识的分享网站

  |   本站Feed      

innodb_flush_method带来的性能影响

2009-07-22 13:10:48  |   才被阅读:1,293 次  |   要评论?
分类: MySQL优化设计  |   发布: OurMySQL  |   来源:Taobao DBA Team
标签: , , ,

innodb_flush_method有三个值,分别是fdatasync,O_DSYNC和O_DIRECT,其中fdatasync是默认值。它们控制了InnoDB刷新日志和数据的模式。

InnoDB使用fsync()函数去更新日志和数据文件。

fdatasync

InnoDB使用O_SYNC模式打开并更新日志文件,用fsync()函数去更新数据文件。

o_dsync

InnoDB使用O_DIRECT模式打开数据文件,用fsync()函数去更新日志和数据文件。

o_direct

以上图测试的是insert效率。横坐标为unix时间戳,纵坐标为十秒内insert的执行量。

从上面的对比可以看出,单纯从写入的角度讲,默认的fdatasync性能最佳,其次是O_DSYNC,最差的是O_DIRECT。

相关文章

Leave a Reply