[发明专利]一种基于异构存储的IO限流方法、装置和介质在审
| 申请号: | 202011395058.2 | 申请日: | 2020-12-03 | 
| 公开(公告)号: | CN112463062A | 公开(公告)日: | 2021-03-09 | 
| 发明(设计)人: | 苑忠科 | 申请(专利权)人: | 北京浪潮数据技术有限公司 | 
| 主分类号: | G06F3/06 | 分类号: | G06F3/06 | 
| 代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 史翠 | 
| 地址: | 100085 北京*** | 国省代码: | 北京;11 | 
| 权利要求书: | 查看更多 | 说明书: | 查看更多 | 
| 摘要: | |||
| 搜索关键词: | 一种 基于 存储 io 限流 方法 装置 介质 | ||
本发明实施例公开了一种基于异构存储的IO限流方法、装置和介质,依据存储设备的业务指标,设置卷的最大资源分配量、I/O队列深度阈值和I/O队列水平线;根据卷的最大资源分配量、存储设备的通道数量,计算通道对应的独占I/O资源量和共享I/O资源量。依据卷的数量以及通道的数量,动态调整卷和通道各自对应的I/O资源量;并依据卷的卷活动I/O数量、I/O队列深度阈值以及I/O队列水平线,为卷和通道分配额外的I/O资源量。统计目标通道的通道活动I/O数量;若通道活动I/O数量不满足资源放行规则,则将新I/O任务放入等待队列,可以使异构场景业务的稳定性大幅提高,提升了IO限流效果,有效的减少了QoS问题。
技术领域
本发明涉及存储系统技术领域,特别是涉及一种基于异构存储的IO限流方法、装置和计算机可读存储介质。
背景技术
异构存储作为一种存储系统的高级特性,可以实现将其它存储系统映射的卷接管到本存储系统中,以起到整合存储资源的目的。由于现存主流存储系统众多,包括同一厂商内部的存储系统系列、型号,这对管理后端存储的功能造成了一定的难度。
在实际的应用中,发现由于后端存储设备的性能、稳定性各异,导致前端主存储系统在处理IO时易发生服务质量(Quality of Service,QoS)相关的问题,包括:存储系统资源分配不足,导致后端存储实际性能利用不充分;存储系统IO限流控制工作不足导致出现IO拥塞,异构设备或卷离线、间断或因排队过多导致IO超时;当存在多个后端存储设备或多个卷时,由于资源分配不均或过于平均影响整体性能和稳定性。
可见,如何提升IO限流效果,是本领域技术人员需要解决的问题。
发明内容
本发明实施例的目的是提供一种基于异构存储的IO限流方法、装置和计算机可读存储介质,可以提升IO限流效果。
为解决上述技术问题,本发明实施例提供一种基于异构存储的IO限流方法,包括:
依据存储设备的业务指标,设置卷的最大资源分配量、I/O队列深度阈值和I/O队列水平线;
根据所述卷的最大资源分配量、所述存储设备的通道数量,计算通道对应的独占I/O资源量和共享I/O资源量;
依据卷的数量以及通道的数量,动态调整卷和通道各自对应的I/O资源量;并依据卷的卷活动I/O数量、所述I/O队列深度阈值以及所述I/O队列水平线,为卷和通道分配额外的I/O资源量;
统计目标通道的通道活动I/O数量;其中,所述目标通道为接收所述新I/O任务的通道;
若所述通道活动I/O数量不满足所述资源放行规则,则将所述新I/O任务放入等待队列;其中,所述资源放行规则依据卷和通道各自对应的I/O资源量以及卷和通道对应的额外的I/O资源量设置。
可选地,所述依据卷的数量以及通道的数量,动态调整卷和通道各自对应的I/O资源量包括:
当检测到卷的数量发生变化时,调整每个卷所包含通道的独占I/O资源量和共享I/O资源量;
当检测到端口连线数量发生变化时,调整每个卷所对应的资源分配量。
可选地,所述依据卷的卷活动I/O数量、所述I/O队列深度阈值以及所述I/O队列水平线,为卷和通道分配额外的I/O资源量包括:
判断所述当前卷的卷活动I/O数量是否大于I/O队列高水平线;
若所述当前卷的卷活动I/O数量大于I/O队列高水平线,则依据所述I/O队列深度阈值对所述当前卷分配额外的I/O资源,并依据所述当前卷包含的通道数量,为所述当前卷所包含的每个通道分配额外的I/O资源量。
可选地,在所述若所述当前卷的卷活动I/O数量大于I/O队列高水平线之后还包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京浪潮数据技术有限公司,未经北京浪潮数据技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202011395058.2/2.html,转载请声明来源钻瓜专利网。





