磁盘 I/O 优化

1. 性能检测

  我们的应用程序通常都需要访问磁盘系统,而磁盘 I/O 通常都很耗时, 要判断 I/O 是否是一个瓶颈,有一些参数指标可以参考.

  我们可以压力测试应用程序看系统的 I/Owait 指标是否正常. 例如,测试服务器有4个 CPU, 那么理想的 I/O wait 参数应该不超过 25% ,如果超过25%  那么I/O 很可能成为应用程序的性能瓶颈. Linux 操作系统下可以通过 iostat 命令查看.

[root@iZ239yqa63mZ ~]# iostat
Linux 2.6.-431.23..el6.x86_64 (iZ239yqa63mZ) // _x86_64_ ( CPU) avg-cpu: %user %nice %system %iowait %steal %idle
0.37 0.00 0.27 5.28 0.00 94.08 Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
xvda 5.08 208.63 2.38
xvdb 1.95 30.33 0.35

  通常我们在判断 I/O 性能时还会看另外一个参数. 就是 IOPS ,这个和存储在磁盘上的数据块的大小和访问的方式也有关, 但主要还是由磁盘的转速决定的. 磁盘的转速越高,磁盘的 IOPS 也越高.

2. 提升 I/O 性能

  通常提升磁盘 I/O 性能的方法有:

  1. 增加缓存,减少磁盘访问次数.

  2. 优化磁盘的管理系统,设计最优的磁盘方式策略,已经磁盘的寻址策略, 这是在底层操作系统层面上考虑的.

  3. 设计合理的数据存储数据块,以及访问这些数据块的策略,这些是在应用层面上考虑的,例如: 我们可以给存放的数据设计索引,通过寻址索引来加快和减少磁盘的访问量,还可以采用异步和非阻塞的方式加快磁盘的访问速度.

  4. 应用合理的 Raid

最新文章

  1. Mongo DB 2.6 需要知道的一些自身限定
  2. FreeMarker标签与使用
  3. 【bzoj2705】 SDOI2012—Longge的问题
  4. tail 命令 查看Tomcat目录下日志的最后几行的方法
  5. Java数据结构——双端链表
  6. 关于Redis的启动过程
  7. struts2 <s:iterator> status属性
  8. if [-f build/core/envsetup.mk -a -f Makefile ]; then
  9. curl Protocol 'http not supported or disabled in libcurl
  10. Swift开发语法
  11. Maven项目中提示:Eclipse “cannot be resolved to a type” error
  12. 机器学习之分类问题实战(基于UCI Bank Marketing Dataset)
  13. JavaWeb 后端 <十四> 文件上传下载
  14. shim 和 polyfill
  15. Linux IPC实践(4) --System V消息队列(1)
  16. POJ2385——Apple Catching
  17. ACM在线模板
  18. jsp模板继承
  19. python 正则括号的使用及踩坑
  20. 打通WordPress和微信公众号

热门文章

  1. C++程序设计方法3:函数重写
  2. 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第4章编程练习2
  3. web 和 java 资源
  4. Hibernate(12)_基于主键的双向1对1
  5. C#网络编程技术微软Socket实战项目演练(三)
  6. wriesharek同时监听多个端口
  7. SpringCloud无废话入门01:最简SpringCloud应用
  8. Android: Android Studio签名打包的两种方式(zz)
  9. Webhook 实践 —— 自动部署
  10. 安装了 R2 Integration Servic 之后,SQL Server 2008 Management Studio报错