8.5.8 Optimizing InnoDB Disk IO 优化InnoDB Disk I/O

8.5.8 Optimizing InnoDB Disk IO 优化InnoDB Disk I/O

如果你遵循最佳实践对于数据库的设计和调优技术对于SQL操作,

但是你的数据库仍旧是很慢的 由于沉重的disk I/O 活动,

探索这些low-level 技术相关的disk I/O

如果unix top攻击或者Windows Task Manager 显示CPU 使用率是小于70%,你的workload 可能是磁盘。

当表中的数据是cache在InnoDB buffer pool,它可以通过查询不需要任何的disk I/O

指定buffer pool的大小使用innodb_buffer_pool_size

这个内存的区域是很重要的 对于繁忙的数据 通常指定物理内存的80%

在一些Linux 或者Unix 的一些版本, flush 文件到磁盘使用Unix的 fsync() call( InnoDB 默认使用)

类似的方法是出奇的慢,如果数据库写性能是一个问题,innodb_flush_method parameter set to O_DSYNC.

当使用 InnoDB 存储引擎在 Solaris 10 for x86_64 architecture (AMD Opteron),

使用direct I/O用于 InnoDB-related files,为了避免InnoDB 性能恶化。

使用direct I/O 对于一个UFS 文件系统用于存储InnoDB-related files,

挂载它用 forcedirectio option

当使用InnoDB 存储引擎 设置一个大的innodb_buffer_pool_size的值在任何的 Solaris 2.6版本上

和任何其他的平台,

InnoDB 数据文件和Log files 在裸设备上或者一个单独的I/O UFS 文件系统

不要放其他的MySQL 数据文件, 比如 MyISAM 表,

在一个direct I/O 文件系统。可执行文件或者库不用放在direct I/O 文件系统

如果你有额外的存储设备 来配置一个RAID 配置或者 符号连接到不同的磁盘Section 8.12.3, “Optimizing Disk I/O” for

additional low-level I/O tips.

如果吞吐量下降因为InnoDB 检查点操作 ,考虑增加 innodb_io_capacity configuration option.

更高的值可以导致更频繁的flush,避免积压,这可能会造成吞吐量下降

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

scan724

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值