[发明专利]一种对存储阵列系统的性能进行仿真的方法及装置有效
申请号: | 201310529354.0 | 申请日: | 2013-10-30 |
公开(公告)号: | CN103605833B | 公开(公告)日: | 2017-01-04 |
发明(设计)人: | 陈刚 | 申请(专利权)人: | 华为数字技术(苏州)有限公司 |
主分类号: | G06F17/50 | 分类号: | G06F17/50 |
代理公司: | 北京三高永信知识产权代理有限责任公司11138 | 代理人: | 黄厚刚 |
地址: | 215123 江苏省苏州市苏*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 存储 阵列 系统 性能 进行 仿真 方法 装置 | ||
技术领域
本发明涉及计算机领域,特别涉及一种对存储阵列系统的性能进行仿真的方法及装置。
背景技术
随着海量数据存储的时代到来,存储数据的存储阵列系统会越来越复杂,当对该存储阵列系统的参数进行调整或者对该存储阵列系统重新部署时都要进行测试,而测试的周期较长,规模较大,成本较高,所以对存储阵列系统的性能进行仿真的方法受到了广泛的关注。
其中,存储阵列系统包括控制器阵列和存储介质阵列,存储介质阵列包括硬盘,现有技术对该硬盘进行仿真,例如,卡梅隆大学的disksim软件是一个高效、准确和高度可配置的磁盘系统模拟器。由于控制器阵列是影响存储阵列系统性能的最大因素,而现有技术只是简单地对该存储介质阵列包括的硬盘进行仿真,并没有对该存储阵列系统包括的控制器阵列进行仿真,所以现有技术对该存储阵列系统的性能进行仿真的仿真度较低。
发明内容
为了解决现有技术的问题,本发明实施例提供了一种对存储阵列系统的性能进行仿真的方法及装置。所述技术方案如下:
第一方面,提供了一种对存储阵列系统的性能进行仿真的方法,所述方法包括:
接收输入输出IO请求消息,所述IO请求消息中至少携带所述IO请求消息访问的逻辑地址;
根据预设的消息路径和所述消息路径包括的每个系统性能模块的路由规则,从存储阵列系统包括的控制器阵列中查找缓存模块;
根据所述IO请求消息访问的逻辑地址,在所述查找的缓存模块中读取或写入数据,以实现对所述存储阵列系统的性能进行仿真。
结合第一方面,在上述第一方面的第一种可能的实现方式中,所述根据预设的消息路径和所述消息路径包括的每个系统性能模块的路由规则,从存储阵列系统包括的控制器阵列中查找缓存模块,包括:
将接收所述IO请求消息的系统性能模块确定为当前系统性能模块;
判断所述当前系统性能模块是否为所述控制器阵列包括的缓存模块;
如果是,则将所述当前系统性能模块确定为查找的缓存模块;
如果否,则根据预设的消息路径和所述当前系统性能模块的路由规则,将所述IO请求消息转发到所述消息路径包括的下一个系统性能模块,返回判断所述当前系统性能模块是否为所述控制器阵列包括的缓存模块。
结合第一方面,在上述第一方面的第二种可能的实现方式中,如果所述IO请求消息为写请求消息,则所述IO请求消息中还携带待写入的数据,
相应地,所述根据所述IO请求消息访问的逻辑地址,在所述查找的缓存模块中读取或写入数据,包括:
如果所述IO请求消息为读请求消息,则根据所述逻辑地址从所述缓存模块中读取对应的数据,并返回IO读响应消息,所述IO读响应消息包括所述逻辑地址和读取的数据;
如果所述IO请求消息为写请求消息且采用回写方式写数据,则将所述待写入的数据插入所述缓存模块包括的写数据列表,并返回IO写响应消息。
结合第一方面的第二种可能的实现方式,在上述第一方面的第三种可能的实现方式中,所述根据所述逻辑地址从所述缓存模块中读取对应的数据,并返回IO读响应消息,包括:
根据所述逻辑地址从所述缓存模块包括的读数据列表中读取对应的数据;
如果读取到所述逻辑地址对应的所有数据,则产生IO读响应消息,返回所述IO读响应消息,并将所述读取的数据移动至所述读数据列表的表尾;
如果没有读取到数据或者读取到所述逻辑地址对应的部分数据,则向存储介质阵列发送预读请求,所述预读请求中携带读取数据失败的逻辑地址;
当从所述存储介质阵列中获取到数据时,接收预读响应消息,将所述获取的数据存储在所述读数据列表中;
根据所述IO请求消息需要读取的数据的原数据长度和所述读数据列表中所述IO请求消息对应的数据的当前数据长度,产生IO读响应消息,并返回所述IO读响应消息。
结合第一方面的第三种可能的实现方式,在上述第一方面的第四种可能的实现方式中,所述将所述获取的数据存储在所述读数据列表中,包括:
如果所述读数据列表已满或者所述读数据列表未满且所述读数据列表剩余的空间小于所述获取的数据占用的空间,则从所述读数据列表的表头开始删除数据,以使所述获取的数据存储到所述读数据列表中;
如果所述读数据列表未满且所述读数据列表剩余的空间大于或等于所述获取的数据占用的空间,则将所述获取的数据直接插入所述读数据列表中。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华为数字技术(苏州)有限公司,未经华为数字技术(苏州)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201310529354.0/2.html,转载请声明来源钻瓜专利网。