超高I/O型弹性云服务器本地盘读IOPS性能调优方法
性能调优场景
超高I/O型弹性云服务器采用QingTian架构,配备高性能NVMe(Non-Volatile Memory Express)本地磁盘,且每个规格中包含1块至12块数量不等的NVMe本地盘。
推荐I9系列弹性云服务器中64个vCPU及以上的规格使用本方法进行性能调优。调整后可优化本地盘的读IOPS性能,但对访问时延可能存在一定影响。
当前需要通过调整中断聚合数量来进行性能优化,以达到预期性能指标的规格包括:i9.16xlarge.4、i9.32xlarge.4、i9.16xlarge.8、i9.32xlarge.8。
背景知识
中断聚合(Interrupt Coalescing)是用于优化计算机系统或网络设备中频繁发生的硬件中断问题的优化机制,通过将多个中断合并为一个中断来降低CPU的中断处理开销,从而提升系统性能。
中断聚合数量(Interrupt Coalescing Count)是NVMe设备中的一个关键参数,用于控制中断的聚合次数。具体来说,中断聚合数量决定了设备在触发中断之前需要累积多少个I/O操作。例如,如果中断聚合数量设置为0x0109(十进制为265),则设备会在累积265个I/O操作后触发一次中断。通过调整这个参数,可以平衡中断频率和延迟之间的关系。
中断聚合的数量需要根据具体的硬件配置(如vCPU、存储设备的负载等)进行调整,以达到最佳性能。在实际应用中,中断聚合数量设置过大或过小都会对性能产生负面影响,因此根据不同的CPU和存储设备配置,合理设置中断聚合数量是性能调优的重要环节。- 中断聚合数量过小:会导致中断过于频繁,增加CPU的中断处理开销,降低系统性能。
- 中断聚合数量过大:可能会导致延迟增加,影响实时性任务的响应。
厂商通常会提供一个默认的最大值作为参考,但实际应用中需要根据具体场景进行调整。
您可以通过nvme set-feature命令,动态调整NVMe设备的中断聚合数量,有效减少CPU的中断处理开销,提升存储设备的性能。建议根据实际硬件配置和负载需求,逐步测试并优化中断聚合数量,以达到最佳性能。
调优过程中,建议使用性能监控工具监控设备性能指标,确保调整后的设置能够提升性能。
操作步骤
本操作以i9.32xlarge.4规格为例,对本地盘的读IOPS性能进行批量调优。
- 登录控制台,进入弹性云服务器列表页面。
- 单击管理控制台左上角的
,选择区域和项目。
- 选择要登录的弹性云服务器,单击“操作”列下的“远程登录”。
支持通过多种方式连接实例,具体操作,请参见登录Windows ECS和登录Linux ECS。
- 执行以下命令行,对本地盘进行批量中断聚合调优。
for i in $(seq 0 7);do nvme set-feature /dev/nvme$i -f 0x08 --value 0x0109; done
图1 本地盘读IOPS性能批量调优表1 命令参数说明 参数
参数说明
seq 0 7
遍历NVMe设备编号0到7,即调整所有8个NVMe设备。 如果是12个nvme设备,则编号为0到11,以此类推。
请您根据实际情况调整设备编号范围,规格包含的nvme设备数量,请参见超高I/O型。
/dev/nvme$i
表示要对系统中第(i+1)个NVMe设备进行操作。
-f 0x08
0x08表示设置中断聚合数量特征。
--value 0x0109
设置中断聚合数量为0x0109,表示设备在累积265个I/O操作后触发一次中断。
说明:0x0109是厂商推荐的参考值,但实际应用中可能需要根据具体场景进行调整。建议从参考值开始,逐步测试并优化。