• Linux中的MFS分布式文件系统


    目录

    一、MFS分布式文件系统

    1、MooseFS简介

    2、Moose File System的体系结构

    (1)MooseFS Master

    (2)MooseFS Chunk Server

    (3)MooseFS Metalogger

    (4)MooseFS Client

    (5)MooseFS CLI

    二、MFS命令介绍

    三、集群部署

    四、Storage Classes

    1、Storage Classes简介

    2、 LABEL简介

    3、示例:

    五、Moose File System的pacemaker高可用

    1、安装 Master Servers

    2、pacemaker高可用

    3、ISCSI

    4、添加集群资源

    5、应用


    一、MFS分布式文件系统

    1、MooseFS简介

          MFS(Moose File System)是一个基于分布式网络文件系统的开源存储系统。MFS可以在多台计算机上组织文件并提供统一的文件系统访问。MFS的主要特点是高可用性、可靠性和扩展性。它使用存储在多个节点上的数据进行数据冗余,并使用快速而可靠的网络传输数据。MFS还支持在运行时动态添加和删除节点,以便随着系统需求的变化而进行快速和灵活的扩展。

    2、Moose File System的体系结构

    Moose File System是一个分布式文件系统,它由多个组件组成。

    (1)MooseFS Master

          MooseFS Master是一个开源的分布式文件系统管理器,它能够管理一个或多个MooseFS Chunk Servers,为客户端提供可靠的文件存储和访问服务。MooseFS Master使用Master-Slave架构,它可以处理超过数百个Chunk Server的集群,并且具有高可用性和可伸缩性。它支持多种数据备份策略,可以将数据备份到多个Chunk Server上,从而提高数据的可靠性和容错性。MooseFS Master还提供了Web界面和命令行工具,方便用户管理和监控文件系统的运行状态。

    (2)MooseFS Chunk Server

          MooseFS Chunk Server 是MooseFS 分布式文件系统中的组成部分之一,主要负责存储和管理文件系统中的文件数据块。每个 MooseFS Chunk Server 可以存储多个数据块,并与 MooseFS Master Server 进行通信以保持文件系统的一致性和可用性。MooseFS Chunk Server 可以在多台服务器上部署,因此 MooseFS 文件系统可以通过多个节点并行地处理文件的存储、访问和备份。

    (3)MooseFS Metalogger
    • MooseFS Metalogger是一个MooseFS集群的组件,它负责管理和记录MooseFS文件系统的元数据。它的作用是确保元数据的一致性和可靠性,以避免数据丢失或损坏的情况发生。
    • MooseFS Metalogger可以运行在独立的服务器上,也可以与其他MooseFS组件一起运行在同一台服务器上。它使用特殊的协议与其他MooseFS组件进行通信,以确保数据和元数据的一致性。
    • 在MooseFS集群中,Metalogger通常设置为主/备两个节点,以确保在主节点故障时备用节点能够接管并继续提供服务,从而实现高可用性。
    (4)MooseFS Client
    • MooseFS是一种开源的分布式文件系统,它允许用户在多台服务器之间共享数据。MooseFS Client是MooseFS文件系统的客户端,用户可以使用MooseFS Client来访问MooseFS文件系统中存储的数据。 
    • MooseFS Client提供了一个用户空间工具,它包括了一个命令行界面和一个文件系统挂载程序。使用MooseFS Client,用户可以将MooseFS文件系统挂载到本地文件系统中,就像挂载任何其他文件系统一样。这意味着用户可以直接在本地系统上访问MooseFS文件系统中的数据,而无需知道它实际上存储在哪个服务器上。
    • MooseFS Client使用自身的协议来访问MooseFS服务器,这意味着它可以在不同的操作系统上运行,包括Linux、BSD、Solaris和Windows。此外,MooseFS Client还支持许多其他高级功能,例如安全访问、文件缓存、数据压缩和限制带宽等功能。
    (5)MooseFS CLI
    • MooseFS CLI是一个基于命令行界面的管理工具,用于管理MooseFS文件系统。它提供了一组命令,可用于查看和修改MooseFS中的文件、目录和元数据,以及监控系统性能和状况。
    • MooseFS CLI可以通过SSH远程连接到MooseFS服务器,也可以在本地运行。它可以执行诸如创建、删除、重命名、移动和复制文件等基本操作,同时还可以进行更高级的操作,如设置文件ACL、挂载磁盘、调整容量限制等操作。
    • MooseFS CLI还支持命令行自动补全和命令历史记录等功能,使得操作更加方便和高效。它是MooseFS系统中一个十分重要的管理工具,非常适合那些需要以命令行方式管理文件系统的用户。

          这些组件共同协作,实现文件的存储和访问。MooseFS的设计使得它能够扩展到数百个节点,可以存储数PB的数据。

    二、MFS命令介绍

    1. mfsmount:将 MooseFS 挂载到本地文件系统。

    2. mfsmetarestore:用于将备份中的元数据恢复到 MooseFS 文件系统中。

    3. mfsbackup:用于对 MooseFS 文件系统创建备份。它可以备份整个文件系统或单个目录。

    4. mfsmount.cfg:MooseFS Mount 配置文件。它包含有关如何将 MooseFS 文件系统挂载到本地文件系统的信息。

    5. mfsgooglecache:使用 Google Cloud Storage 作为 MooseFS 缓存。它可以帮助用户提高 MooseFS 系统的性能。

    6. mfshdd:硬盘诊断工具。它可以帮助检测 MooseFS 存储节点中硬盘的健康状态。

    7. mfsgetgoal: 查看设置的副本数

    8. mfssetgoal:设置副本数。(必须设置在 1 到 9 之间,建议不要使用 1)。如果设置的副本数高于 Chunkservers 的总数,则副本数为 Chunkservers 的总数。

    9. mfsdirinfo:查看目录详细信息。

    10. mfsfileinfo:查看文件详细信息。

    11. mfsgettrashtime:查看已删除文件(垃圾)的保留时间(默认为 1天)。

    12. mfssettrashtime:修改已删除文件(垃圾)的保留时间。

    13. mfsscadmin:用于管理MoosesFS存储集群中的文件系统实例。行实例的创建、删除、添加和删除存储节点,以及设置哈希分片策略等操作。

    14. mfssetsclass:用来设置一个或多个文件或目录的存储类别。存储类别确定了文件或目录在存储设备上的位置和使用的存储策略,例如,高速缓存、磁盘存储、或者归档存储。

      mfssetsclass [-c class] [-s] [-r] [-d] [-f] file or directory ...
      

      等;

    三、集群部署

    主机

    ip

    角色

    mfs1

    192.168.67.41

    Master Servers

    mfs2

    192.168.67.42

    Chunkservers
    mfs3

    192.168.67.43

    Chunkservers
    mfs4

    192.168.67.44

    Clients
    mfs5

    192.168.67.45

    Chunkservers

    软件安装(Master Servers):

    软件仓库(所有节点)

    1. curl "https://repository.moosefs.com/RPM-GPG-KEY-MooseFS" > /etc/pki/rpm-gpg/RPM-GPG-KEY-MooseFS
    2. curl "http://repository.moosefs.com/MooseFS-3-el7.repo" > /etc/yum.repos.d/MooseFS.repo

    安装:

    1. yum install moosefs-master moosefs-cgi moosefs-cgiserv moosefs-cli
    2. systemctl enable --now moosefs-master.service
    3. systemctl enable --now moosefs-cgiserv.service

    添加解析

     Chunkservers节点安装

    yum install moosefs-chunkserver

    修改配置:

    1. cd /etc/mfs/
    2. vim mfshdd.cfg
    3. mkdir chunk1

    三节点同上

    Clients节点安装:

    yum install moosefs-client

    修改文件(挂载点)

    1. cd /etc/mfs/
    2. vim mfsmount.cfg
    3. /mnt/mfs
    4. cd /mnt
    5. mkdir mfs
    6. mfsmount

    所有节点都要添加解析

    测试

    1. mkdir dir1
    2. mkdir dir2
    3. cd dir1
    4. touch file1 vim file1 (文件不能为空)
    5. mfsfileinfo file1
    6. mfsgetgoal -k dir2/
    7. mfssetgoal -r 1 dir2/
    8. cd dir2
    9. touch file1
    10. mfsfileinfo file1

    四、Storage Classes

    1、Storage Classes简介

           MooseFS的Storage classes可以根据数据的需求来灵活的配置和选择不同的存储类型。它们可以根据应用需求来提供高性能的读写速度、数据的冗余备份和大规模的数据存储。

    2、 LABEL简介

           label是指对文件或目录进行标记,以便于对它们进行管理和区分。label可以是任何文本字符串,通常用于指示文件或目录的用途、状态或其他属性。例如,您可以为某个目录设置一个label,以指示它是用于存储备份文件,或者为某个文件设置一个label,以指示它是具有高优先级的任务数据。MooseFS使用label可以帮助用户更好地组织和管理文件系统中的数据。

    3、示例:

    同理扩容节点三

    修改配置 添加标签

    创建存储类及应用

    (1)2S

    1. mfsscadmin create 2S class 2s
    2. cd dir1
    3. mfssetsclass -r class 2s file1
    4. mfsfileinfo file1

    (2) A,B

    1. mfsscadmin create A,B class_ab
    2. mfssetsclass -r class ab file1
    3. mfsfileinfo file1

    (3)S,H

    1. mkdir dir3
    2. mfsscadmin create S,H class sh
    3. touch file1
    4. mfssetsclass -r class sh file1

    (4)3S

    1. mfssetgoal -r 3 dir3/
    2. 修改标签
    3. mfsscadmin create 3S class 3s
    4. mfssetsclass -r class 3s file1
    5. mfsfileinfo file1

    所以创建的存储类

    各种组合都可以有 

    五、Moose File System的pacemaker高可用

    主机

    ip

    角色

    mfs1

    192.168.67.41

    Master Servers    +   pacemaker    +   ISCSI(Client)

    mfs2

    192.168.67.42

    Chunkservers
    mfs3

    192.168.67.43

    Chunkservers
    mfs4

    192.168.67.44

    Clients    +   ISCSI(Server)
    mfs5

    192.168.67.45

    Chunkservers
    mfs6

    192.168.67.46

    Master Servers    +   pacemaker    +   ISCSI(Client)

    1、安装 Master Servers

    防止两台高可用主机mfs用户id不同

    1. curl "https://repository.moosefs.com/RPM-GPG-KEY-MooseFS" > /etc/pki/rpm-gpg/RPM-GPG-KEY-MooseFS
    2. curl "http://repository.moosefs.com/MooseFS-3-el7.repo" > /etc/yum.repos.d/MooseFS.repo
    3. yum install moosefs-master moosefs-cgi moosefs-cgiserv moosefs-cli
    4. systemctl enable --now moosefs-master.service
    5. systemctl enable --now moosefs-cgiserv.service

    查看id

    2、pacemaker高可用

    配置软件仓库

    1. vim /etc/yum.repo.d/yyl.repo
    2. [HighAvailability]
    3. name=rhel7.6 HighAvailability
    4. baseurl=file:///media/addons/HighAvailability
    5. gpgcheck=0

    安装高可用

    yum install -y pacemaker pcs psmisc policycoreutils-python

    启动pcsd服务  设置用户密码   节点认证

    1. systemctl enable --now pcsd.service
    2. ssh mfs6 systemctl enable --now pcsd.service
    3. echo westos | passwd --stdin hacluster
    4. ssh mfs6 'echo westos | passwd --stdin hacluster'
    5. pcs cluster auth mfs1 mfs6

    创建集群

    pcs cluster auth mfs1 mfs6

    启动集群

    1. pcs cluster start--all
    2. pcs cluster enable --all

    禁用stonith

    pcs property set stonith-enabled=false

    3、ISCSI

    服务端配置:

    在mfs4上添加一块硬盘

    1. yum install targetcli -y
    2. systemctl enable --now target

    配置

    1. /backstores/block create yyl:storage /dev/sdb1
    2. /iscsi create iqn.2023-11.org.yyl:storage
    3. /iscsi/iqn.2023-11.org.yyl:storage/tpg1/luns create /backstores/block/yyl:storage
    4. /iscsi/iqn.2023-11.org.yyl:storage/tpg1/acls create iqn.2023-11.org.yyl:yylkey1

     在高可用集群做客户端(mfs1,mfs6)

    安装客户端:

    yum install iscsi-initiator-utils.x86_64 -y

    编辑认证文件

    1. vim /etc/iscsi/initiatorname.iscsi
    2. systemctl restart iscsid

     

    客户端测试

    1. iscsiadm -m discovery -t st -p 192.168.67.44
    2. iscsiadm -m node -T iqn.2023-11.org.yyl:storage -p 192.168.67.44 -l

    在服务端创建分区 格式化:

    1. fdisk /dev/sdb
    2. mkfs.xfs /dev/sdb1

     测试挂载

    应用:

    在mfs文件系统

    修改权限    可以启动就表示成功

    取消挂载

    4添加集群资源

    1. pcs resource create vip ocf:heartbeat:IPaddr2 ip=192.168.67.200 op monitor interval=30s
    2. pcs resource create mfs ocf:heartbeat:Filesystem device=/dev/sdb1 directory=/var/lib/mfs fstype=xfs
    3. pcs resource create mfs-master systemd:moosefs-master op monitor interval=60s
    4. pcs resource group add groupmfs vip mfs mfs-master

    5、应用

    在集群所有节点添加解析

    测试:

  • 相关阅读:
    深度学习之基于Pytorch和OCR的识别文本检测系统
    SpringCloud Alibaba - Sentinel 高级玩法,修改 Sentinel-dashboard 源码,实现 push 模式
    GSAman | 我「玩着游戏」就把「科研做了」
    STM32 硬件IIC 控制OLED I2C卡死问题
    golang八股文整理(持续搬运)
    Java架构师基础框架设计
    YTM32的增强型定时器eTMR外设模块详解
    代码随想录算法训练营第一天(C)| 704. 二分查找 27. 移除元素
    生成式AI模型量化简明教程
    代码随想录打卡第五十三天|309.最佳买卖股票时机含冷冻期 ● 714.买卖股票的最佳时机含手续费
  • 原文地址:https://blog.csdn.net/weixin_56744753/article/details/134538582