[发明专利]一种分布式存储的纠删码实现方法及装置有效
申请号: | 201510808175.X | 申请日: | 2015-11-19 |
公开(公告)号: | CN105404561B | 公开(公告)日: | 2019-04-12 |
发明(设计)人: | 丁强 | 申请(专利权)人: | 浙江宇视科技有限公司 |
主分类号: | G06F11/10 | 分类号: | G06F11/10;G06F3/06 |
代理公司: | 北京博思佳知识产权代理有限公司 11415 | 代理人: | 林祥 |
地址: | 310051 浙江省杭州市滨江*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 分布式 存储 纠删码 实现 方法 装置 | ||
1.一种分布式存储系统纠删码实现方法,其特征在于,包括:
接收目标客户端发送的针对目标目录的目录创建指令,所述目录创建指令中包括所述目标目录对应的纠删策略;
根据所述纠删策略确定所述目标目录对应的多个目标子目录,以及各目标子目录关联的目标存储服务节点;其中,同一目标目录对应的多个目标子目录关联的目标存储服务节点不同;
存储所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系,以使客户端根据所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系对所述目标目录进行文件创建和/或数据读写。
2.根据权利要求1所述的方法,其特征在于,所述根据所述纠删策略确定所述目标目录对应的多个目标子目录,以及各目标子目录关联的目标存储服务节点之后,还包括:
将所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系发送给所述目标客户端,以使所述目标客户端接收到在所述目标目录中创建目标文件的文件创建请求时,根据所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系,向所述目标存储服务节点发送创建所述目标文件的文件创建指令,由所述目标存储服务节点在相应的目标子目录下创建所述目标文件。
3.根据权利要求1所述的方法,其特征在于,所述存储所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系之后,还包括:
接收客户端发送的针对目标目录的查询请求;
响应所述查询请求,向该客户端发送所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系,以使该客户端根据该目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系,确定所述目标目录下的文件列表。
4.根据权利要求1所述的方法,其特征在于,所述根据所述纠删策略确定所述目标目录对应的多个目标子目录,以及各目标子目录关联的目标存储服务节点之后,还包括:
当所述目标存储服务节点中存在被冗余节点替代的目标存储服务节点时,修改与被替代的目标存储服务节点对应的目标子目录,并将被替代的目标存储服务节点与该被替代的目标存储服务节点关联的目标子目录的对应关系修改为该冗余节点与修改后的目标子目录的对应关系。
5.一种分布式存储系统纠删码实现方法,其特征在于,包括:
向元数据服务器发送针对目标目录的目录创建指令,所述目录创建指令中包括所述目标目录对应的纠删策略,以使所述元数据服务器根据所述纠删策略确定所述目标目录对应的多个目标子目录,以及各目标子目录关联的目标存储服务节点;
根据所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系,对所述目标目录进行文件创建和/或数据读写。
6.根据权利要求5所述的方法,其特征在于,所述根据所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系,对所述目标目录进行文件创建,包括:
接收在目标目录下创建目标文件的文件创建请求;
根据所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系,向所述目标存储服务节点发送创建所述目标文件的文件创建指令,由所述目标存储服务节点在相应的目标子目录下创建所述目标文件。
7.根据权利要求5所述的方法,其特征在于,所述根据所述目标目录、所述目标子目录以及所述目标存储服务节点三者的对应关系,对所述目标目录进行数据写,包括:
接收到针对所述目标目录下的目标文件的数据写入请求;
根据预先设定的数据块大小对待写入数据进行分块,并根据所述纠删策略确定对应的校验数据;
将分块后的待写入数据,以及对应的校验数据按序写入对应的目标存储服务节点的目标子目录下的目标文件中。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于浙江宇视科技有限公司,未经浙江宇视科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201510808175.X/1.html,转载请声明来源钻瓜专利网。