[发明专利]实现CEPH集群缓存的方法和OSD有效
申请号: | 201811555479.X | 申请日: | 2018-12-19 |
公开(公告)号: | CN109799954B | 公开(公告)日: | 2022-02-22 |
发明(设计)人: | 管太阳 | 申请(专利权)人: | 深圳创新科技术有限公司 |
主分类号: | G06F3/06 | 分类号: | G06F3/06 |
代理公司: | 北京德琦知识产权代理有限公司 11018 | 代理人: | 谢安昆;宋志强 |
地址: | 518057 广东省深圳市南山*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 实现 ceph 集群 缓存 方法 osd | ||
本发明提供一种实现CEPH集群缓存的方法和OSD,其中OSD包括与其对应设置的第一缓存;当CEPH集群执行目标OSD的对象的写操作时,先将对象下放至目标第一缓存,再由目标第一缓存将对象写入目标OSD;当CEPH集群执行目标OSD的对象的读操作时,先将目标OSD中的对象读入目标第一缓存,再由目标第一缓存将对象反馈给存储池。基于本发明OSD的CEPH,不仅可以支持EC(Erasure Code)纠删码编码,而且比分层缓存的CEPH的IO性能更佳。
技术领域
本发明涉及计算机领域,特别涉及一种实现CEPH集群缓存的方法和OSD。
背景技术
图1为传统的CEPH集群的结构示意图,其中DATA为输入CEPH的用户数据或者CEPH反馈给用户的数据,第二层是pool存储池,在pool中一个用户数据被抽象为一个pg(placement group),一个pg包括多个存储池对象obj,CEPH通CRUSH算法将存储池对象obj映射至不同的OSD,OSD可视为硬盘Disk的逻辑盘。
传统的CEPH集群没有缓存功能,使得CEPH的IO性能较差。图2为CEPH集群的分层缓存结构示意图,分层缓存基于SSD提出,可以为CEPH客户端提供更好的IO性能,同时分层缓存是SSD(Solid State Disk)在CEPH集群中最广泛的应用。
分级缓存需创建一个由高速而昂贵存储设备SSD组成的第一pool存储池、以及一个相对低速/廉价设备组成的第二pool存储池(与图1中的pool类似)、作为经济存储层,第一pool作为第二pool的缓存层。
客户端与第一pool接口,CEPH分级代理决定何时把第一pool内的存储池对象obj刷回第二pool和后端存储层OSD;第二pool和后端存储层OSD对客户端来说是完全透明的。
分层缓存提高了CEPH集群的IO性能,但也限制了CEPH集群功能,例如第二pool不支持EC(Erasure Code)纠删码编码,而EC广泛用于分布式系统的数据冗余和数据恢复。
发明内容
有鉴于此,本发明提供一种实现CEPH集群缓存的方法和OSD,以解决CEPH集群既需提高IO性能又需兼容EC的问题。
本发明提供一种CEPH集群的OSD,该OSD包括与其对应设置的第一缓存;
当CEPH集群执行目标OSD的对象的写操作时,先将对象下放至目标第一缓存,再由目标第一缓存将对象写入目标OSD;
当CEPH集群执行目标OSD的对象的读操作时,先将目标OSD中的对象读入目标第一缓存,再由目标第一缓存将对象反馈给存储池。
本发明还提供一种实现CEPH集群缓存的方法,包括:
步骤11:将第一存储装置的不同部分分别设置为第一cache分区、第二元数据db分区和第三日志wal分区;
步骤12:将第二存储装置中的硬盘x划分为元数据分区sdx1和用户数据分区sdx2,其中x代表硬盘符号;
步骤13:将第一cache分区和sdx2一起注册到缓存区,生成与sdx2绑定的在第一存储装置中的第一缓存区x;
步骤14:将硬盘x创建为OSDx。
本发明通过对OSD对应设置第一缓存,与图1相比,可以提供更好的IO性能。同时与图2相比,基于本申请OSD的CEPH,不仅可以支持EC(ErasureCode)纠删码编码,且其IO性能比图2的分层缓存还可以进一步提高。
附图说明
图1为传统CEPH的结构图;
图2为现有技术中采用分层缓存的CEPH的结构图;
图3为本发明的CEPH的结构图;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于深圳创新科技术有限公司,未经深圳创新科技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811555479.X/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种快速重建RAID的方法和装置
- 下一篇:一种服务器固态硬盘存储方法及装置