什么是storage class
在moosefs中,storage class允许指定文件的chunks存放在哪些chunkservers上。
storage class使用label进行表达。
为了与早起的版本的goal功能兼容,moosefs 3.0以上会自动在系统中建立1~9 storage class。goal工具将默认在对应的storage class下进行工作。
什么是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三个标签时,它才能用于存放该文件的副本。
相同的子表达式可以通过在表达式前加数字的方式来表示,而不用重复显示声明多次。
实验过程
实验背景:
172.25.2.7 ser7 mfsmaster
172.25.2.8 ser8 chunkserver
172.25.2.9 ser9 chunkserver'
172.25.2.250 真机 mfsclient
关闭selinux 和firewalld
为了实验效果,应该再多加两台chunkserevr,但是由于硬件原因,这里没有加
1.在ser8和ser9上打标签
2.在ser9上也打上标签
3.在客户端创建存储类
为当前目录添加存储类
echo westos >> fstab
如果chunkserver是4台,两台A两台B标签的话,此时应该是两台A标签的chunkserevr被选择存储数据,但是由于现在chunkserevr是2台,每个标签只有一台,因此mfs会将数据存储在两个节点,忽略存储类的标签
新建一份大文件:
3.测试
一个副本,标签是S
- 数据放两份
创建data3目录
5.打包和移动数据
实验: