[发明专利]缓存数据的刷盘方法及装置在审
| 申请号: | 201410712971.9 | 申请日: | 2014-11-28 |
| 公开(公告)号: | CN104461936A | 公开(公告)日: | 2015-03-25 |
| 发明(设计)人: | 张志乐 | 申请(专利权)人: | 华为技术有限公司 |
| 主分类号: | G06F12/08 | 分类号: | G06F12/08;G06F3/06 |
| 代理公司: | 北京同立钧成知识产权代理有限公司 11205 | 代理人: | 马爽;黄健 |
| 地址: | 518129 广东*** | 国省代码: | 广东;44 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 缓存 数据 方法 装置 | ||
技术领域
本发明实施例涉及存储技术,尤其涉及一种缓存数据的刷盘方法及装置。
背景技术
随着固态硬盘(SSD,Solid State Drive)技术的成熟和成本的下降,越来越多的存储系统开始选用SSD作为高速缓冲存储器(cache)介质。
现有技术中,存储系统通过cache技术进行写缓存时:控制器首先接收处理器下发的写请求,其中该写请求包括了待写入数据及该待写入数据对应的逻辑区块地址(LBA,Logical Block Address);其次,将待写入数据写入到SSD的缓存块中,将该缓存块的状态设置为脏数据块,并将该脏数据块的标识与待写入数据对应的LBA进行关联存储;最后在cache的刷盘时机,向磁盘进行数据同步(即将写缓存中的数据发送到磁盘进行存储,本发明中也称为cache的刷盘)。现有技术中,在进行cache刷盘时:控制器采用异步IO的方式向SSD发送多个缓存数据读取请求以获得多个脏数据块的缓存数据;并在接收到任一缓存数据读取请求对应的缓存数据后,将该缓存数据及该缓存数据对应的LBA发送至磁盘,以使磁盘将该缓存数据存储至对应的LBA。
由于磁盘存储数据时,首先需要将磁头步进到LBA所指示的位置,再将缓存数据进行存储;因此,现有技术中,存在控制器刷盘效率低的问题。
发明内容
本发明提供一种缓存数据的刷盘方法及装置,用以解决现有技术中控制器刷盘效率低的问题。
第一方面,本发明提供一种缓存数据的刷盘方法,应用于存储系统中,所述存储系统包括控制器、磁盘和固态硬盘SSD,所述SSD作为所述磁盘的缓存,所述方法由控制器执行,所述方法包括:
向所述SSD发送缓存数据读取请求,所述缓存数据读取请求包括M个待刷盘的脏数据块的标识;
接收所述SSD发送的缓存数据读取响应,所述缓存数据读取响应包括N个待刷盘的脏数据块的缓存数据,M大于或等于N;
根据脏数据块的标识与磁盘逻辑区块地址LBA的对应关系,确定所述N个待刷盘的脏数据块分别对应的LBA;
根据所述N个待刷盘的脏数据块分别对应的LBA,按照LBA由小至大的顺序,依次将所述N个待刷盘的脏数据块的缓存数据存储至所述磁盘。
结合第一方面,在第一方面的第一种可能实现的方式中,所述向所述SSD发送缓存数据读取请求之前,还包括:根据当前刷盘操作的LBA,从全部脏数据块中选择所述M个待刷盘的脏数据块,其中,所述M个待刷盘的脏数据块分别对应的M个LBA均大于所述当前刷盘操作的LBA。
结合第一方面的第一种可能实现的方式,在第一方面的第二种可能实现的方式中,所述根据当前刷盘操作的LBA,从全部脏数据块中选择所述M个待刷盘的脏数据块,包括:根据所述当前刷盘操作的LBA和每个脏数据块的LBA,将所述每个脏数据块放入第一队列或第二队列,所述第一队列中的脏数据块的LBA大于或等于所述当前刷盘操作的LBA,所述第二队列中的脏数据块的LBA小于所述当前刷盘操作的LBA;从所述第一队列中选择所述M个待刷盘的脏数据块。
结合第一方面的第第二种可能实现的方式,在第一方面的第三种可能实现的方式中,从所述第一队列中选择LBA值小的所述M个待刷盘的脏数据块。
结合第一方面的第二种或第三种可能实现的方式,在第一方面的第四种可能实现的方式中,所述方法还包括:根据选择的所述M个待刷盘的脏数据块的LBA,将所述M个待刷盘的脏数据块中LBA连续的脏数据块进行合并,获得合并后的待刷盘的脏数据块;
相应的,向所述SSD发送缓存数据读取请求,所述缓存数据读取请求包括M个待刷盘的脏数据块的标识,包括:向所述SSD发送缓存数据读取请求,所述缓存数据读取请求包括所述合并后的待刷盘的脏数据块的标识。
第二方面,本发明提供一种控制器,所述控制器应用于存储系统中,所述存储系统包括所述控制器、磁盘和固态硬盘SSD,所述SSD作为所述磁盘的缓存,所述控制器包括:
读取请求发送模块,用于向所述SSD发送缓存数据读取请求,所述缓存数据读取请求包括M个待刷盘的脏数据块的标识;
读取响应接收模块,用于接收所述SSD发送的缓存数据读取响应,所述缓存数据读取响应包括N个待刷盘的脏数据块的缓存数据,M大于或等于N;
LBA确定模块,用于根据脏数据块的标识与磁盘逻辑区块地址LBA的对应关系,确定所述N个待刷盘的脏数据块分别对应的LBA;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华为技术有限公司,未经华为技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201410712971.9/2.html,转载请声明来源钻瓜专利网。
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置





