• 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,避免积压,这可能会造成吞吐量下降

  • 相关阅读:
    Unity Shader _Time 的单位
    egg-sequelize 实现 增删改查
    Eggjs 联表查询
    Eggjs 菜单权限管理
    Eggjs 角色管理 -- 对角色树进行 增删改查
    Egg.js 实现一维的对象数组转化为树形数组
    Egg.js 中 Session 的设置和获取
    Egg.js 中 Cookie 的设置和获取
    Egg 安全机制 CSRF 的防范
    Egg middleware 中间件
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13351257.html
Copyright © 2020-2023  润新知