如何计算硬盘、RAID组与Ceph的IOPS

2025-04-19 10:15:38

IOPS (Input/Output Operations Per Second),即每秒进行读写(I/O)操作的次数,多用于数据库等场合,衡量随机访问的性能。存储端的IOPS性能和主机端的IO是不同的,IOPS是指存储每秒可接受多少次主机发出的访问,主机的一次IO需要多次访问存储才可以完成。例如,主机写入一个最小的数据块,也要经过“发送写入请求、写入数据、收到写入确认”等三个步骤,也就是3个存储端访问。

机械硬盘

1、7200硬盘IOPS = 1000/(3 + 1000*(7200/60)/2) = 14010k硬盘IOPS = 1000/(3 + 60000/10000/2像粜杵泳) = 16715k硬盘IOPS = 1000/(3 + 60000/15000/2) = 200其中3为寻道延迟,7200/10k/15k为转速(rpm),1000*(7200/60)/2为旋转延迟(旋转延迟一般用转一圈所需时间的1/2表示),结果为理论峰值,实际还会有系统延迟导致测得IOPS一般低于此值。

如何计算硬盘、RAID组与Ceph的IOPS

RAID组

1、由于RAID组需要校验以提供恢复功能,所以会存在一定写惩罚,这个系数如下:RAID0: 1RAID1: 2RAID5: 4RAID6: 6RAID1-0: 2所以RAID组IOPS = 硬盘写IOPS*硬盘数量*写操作百分比/写惩罚系数 + 硬盘读IOPS*硬盘数量*读操作百分比。以4块IOPS为180的SAS硬盘组RAID 6然后百分百随机写操作为例:IOPS = 180*4/6 = 120

Ceph的IOPS经验公式

1、由于Ceph存储结构不同于物理硬件,所以影响其IOPS的因素主要有网络、副本数量、日志、OSD(硬盘)数量、OSD服务器数量、OSD IOPS等,这里给出一个来自Mirantis的经验公式:IOPS = 硬盘IOPS * 硬盘数量 * 0.88 / 副本数量其中0.88为4-8k随机读操作占比(88%),如果OSD不是以硬盘为单位而是RAID组,则替换公式中对应参数。关于Ceph的IOPS计算仅供参考,计算结果可能会跟物理环境实测有较大偏差。

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
猜你喜欢