MFS分布式文件系统(三) ——Storage class 存储类

本文介绍了Moosefs中的storageclass概念,如何通过label进行chunk节点的标识,并详细讲解了如何为chunk节点打标签、创建存储类以及如何根据存储介质配置数据分布。重点讨论了逻辑运算在副本存储中的应用和存储策略的设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一、什么是storage class

 二、什么是LABEL

 1、给各个chunk节点打上标签

 2、在客户端创建存储类


一、什么是storage class

在moosefs中,storage class允许指定文件的chunks存放在哪些chunkservers上。

storage class使用label进行表达。

为了与早起的版本的goal功能兼容,moosefs 3.0以上会自动在系统中建立1~9 storage class。goal工具将默认在对应的storage class下进行工作。

重新开机后,原本客户端这里就没有内容了,上传到chunkserver,需要在客户端重新挂载
mfsmount /mnt/mfs
mfsmount /mnt/mfs -o nonempty

 二、什么是LABEL

label是可以被分配给chunkserver的字母(a~z,26个字母可选),每个chunkserver可以被打上多个标签(即标记上多个字母,但最多可以打26个label)

完整的label表达式可以由多个子表达式构成,每个子标签之间用逗号分隔。 每个子表达式特指文件副本的一种存储模式。子表达式可以为星号*或一个label schema。

label schema可以是一个label或由加法、乘法和括号构成的复杂表达式。

加法是逻辑“或”的含义,即文件的副本可以被存放在任意含有加法元素label的chunkserver上。==例如,一个文件的storage class是a+b+c,那么任何含有a、b或c标签的chunkserver都可以用来存储该文件的副本。

乘法是逻辑“与”的含义,即文件的副本仅可以存放在包含所有label的chunkserver上。==例如,一个文件的storage class是abc,那么只有当一台chunkserver同时含有abc三个标签时,它才能用于存放该文件的副本。

相同的子表达式可以通过在表达式前加数字的方式来表示,而不用重复显示声明多次。

 1、给各个chunk节点打上标签

chunk2上同理,它的标签是B

 2、在客户端创建存储类

 2A表示A标签创建两个副本,class2A是存储类的名称

如果chunkserver是4台,两台A两台B标签的话,此时应该是两台A标签的chunkserevr被选择存储数据,但是由于现在chunkserevr是2台,每个标签只有一台,因此mfs会将数据存储在两个节点,忽略存储类的标签

 较大文件的存储:

两份冗余:

利用storage class对存储介质,固态盘和机械盘,进行选择和分配。s表示固态盘,h表示机械盘。

 chunk2上的标签是B,H

配置完文件后重启服务

创建新的存储类:

 

设置了数据的存储介质为固态盘,只能存储在chunk1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值