zoukankan      html  css  js  c++  java
  • 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,避免积压,这可能会造成吞吐量下降

  • 相关阅读:
    让源码包apache服务被服务管理命令识别
    zabbix客户端监控脚本shell
    zabbix指定版本自动化安装脚本shell
    haproxy配置详解
    HAproxy 让后端RS记录真实IP
    Centos 7.x系统下忘记用户登录密码,重置root密码的方法
    Win2008 server R2重置登录密码Administrator
    序列自动机总结与例题
    整体二分总结
    容易推错的式子
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13351257.html
Copyright © 2011-2022 走看看