innodb_flush_method带来的性能影响
2009-07-22 13:10:48 |
才被阅读:1,293 次 |
要评论?
分类: MySQL优化设计 | 发布: OurMySQL | 来源:Taobao DBA Team
标签: fdatasync, innodb_flush_method, O_DIRECT, O_DSYNC
分类: MySQL优化设计 | 发布: OurMySQL | 来源:Taobao DBA Team
标签: fdatasync, innodb_flush_method, O_DIRECT, O_DSYNC
innodb_flush_method有三个值,分别是fdatasync,O_DSYNC和O_DIRECT,其中fdatasync是默认值。它们控制了InnoDB刷新日志和数据的模式。
InnoDB使用fsync()函数去更新日志和数据文件。

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

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

以上图测试的是insert效率。横坐标为unix时间戳,纵坐标为十秒内insert的执行量。
从上面的对比可以看出,单纯从写入的角度讲,默认的fdatasync性能最佳,其次是O_DSYNC,最差的是O_DIRECT。
