本文共 2304 字,大约阅读时间需要 7 分钟。
本节书摘来华章计算机《vSphere性能设计:性能密集场景下CPU、内存、存储及网络的最佳设计实践》一书中的第2章 ,第2.4.2节,[美] 克里斯托弗·库塞克(Christopher Kusek) 著 吕南德特·施皮斯(Rynardt Spies)姚海鹏 刘韵洁 译, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
如第7章所述,存储通常对整个虚拟机的性能影响最大。一个机构可以购买具有最强CPU、巨大容量RAM的服务器,但是如果存储能力不能满足性能需求,那么所有虚拟机都将受到影响。正因如此,在投入生产环境之前,拥有一个用来测试和验证存储平台性能的工具集是十分重要的。
Iometer通过在虚拟机上生成一个测试文件,然后针对这个文件运行I/O测试。这个测试文件是定义在分区里的,所以需要在开始测试之前把千兆字节转化为分区。在Maximum Disk Size方框中填入合适的分区的数量,如图2-14所示。这个例子中,使用16777216个分区来生成一个8GB的测试文件。要确保在Targets下选择了适当的磁盘(如果虚拟机有多个虚拟磁盘)并选择了适当的worker数量。每个worker都是一个产生I/O的线程,worker的总数不应该超过分配给虚拟机的vCPU的数量。
Iometer测试文件的大小当运行一个测试文件时,为Iometer测试文件选择合适的大小是很重要的。一个常见的错误是,如果运行一个太小的Iometer测试文件,会导致不正确的结果。当一个操作系统(如Windows)读一个文件时,为了更快地读取它会复制文件的一部分(或整个文件)到RAM中。对于Iometer测试来说,这样就会使结果偏离,因为是从RAM中读取而不是从磁盘中读取。根据经验产生的Iometer测试文件的大小应该至少是配置的RAM大小的两倍。这样就消除了操作系统在RAM中缓存文件的可能性,消除了对结果的影响。 接下来,要为测试定义接入参数,来确定想要产生的I/O类型。例如,如图2-15所示,正在用一个16KB的块产生一个新的接入参数,读和写的比例分别是60%和40%。这些I/O会分成60%随机和40%顺序。如果这个I/O配置符合你的期望,那么运行这个测试你就能知道在这个预期负载下存储的性能。你还可以调整与特定存储阵列相匹配的队列深度。第7章将讨论更多有关队列深度的细节。一旦测试配置完成,就可以简单地选择屏幕上方的绿色标记来启动。选择Results Display标签可以看到实时结果。滑动Update Frequency滑块到一个较低的值,如1或2,如图2-16所示。为了有一个更形象(也更有趣)的视图,选择每行末尾的“>”按钮,可以弹出一个计速器视图,如图2-17所示。
Iometer带有一些默认接入参数,但是最好定义一个与你的环境最相符的参数。尽管可以简单地生成尽可能多的I/O进行测试,来观察存储基础设施极限,但是测试中可能没有那么多的值,除非你试图出售存储阵列。毕竟,如果测试与实际的存储I/O配置文件不准确匹配,最终数据将是没有用的。当测试完成之后,你不仅可以知道能够生成的IOPS的数量,还可以知道记录下来的延迟。一般来说,IOPS的值越高,性能越好,只要IOPS的延迟在合理范围即可。可接受的延迟值取决于使用的存储类型,但对大部分工作负载来说,5~10毫秒是可接受的延迟。应用类型多种多样,所以根据应用类型的不同I/O负载也不同。在使用Iometer之前了解你期望的I/O配置文件是很重要的。输出结果好坏取决于你的测试数据,所以在使用Iometer之前要得到期望的I/O配置文件的准确描述。如果你不确定I/O配置文件是怎样的,请与应用所有者或者软件供应商联系。或者如果你只是希望测试存储阵列的界限,你可以配置Iometer来尝试驱动存储的最大IOPS数量。有关Iometer的更多信息以及工具下载,请访问www.iometer.org。
I/O分析器提供了一个简单易用的图形界面来在虚拟基础设施中运行Iometer测试。它的功能超过Iometer,可以让你回放实际工作负载的轨迹,并且有定时功能,可以在一天的特定时间运行测试。
I/O分析器与简单地运行Iometer还有一点不同,它可以看到esxtop。如果你给ESXi主机授权,I/O分析器可以显示Iometer的测试结果以及相关的esxtop组件。在一个画面中可以看到两个工具的结果,可以大大节省时间,这是使用I/O分析器的一大好处。轻松地运行Iometer测试并查看结果是I/O分析器的关键好处。这个工具由VMware免费提供,有一个VMware Labs Fling,是性能工具箱中的便捷工具。有关I/O分析器的更多信息及下载,请访问。转载地址:http://acsno.baihongyu.com/