理论+实验 详解GFS分布式文件系统

2024-02-24 11:50

本文主要是介绍理论+实验 详解GFS分布式文件系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 一 GlusterFS概述
    • 1.1 GlusterFS简介
    • 1.2 GlusterFS特点
    • 1.3 模块化堆栈式架构
  • 二 GlusterFS工作原理
    • 2.1 GLusterFS工作流程
    • 2.2 弹性HASH算法
  • 三 GlusterFS的卷类型
    • 3.1分布式卷
      • 3.1.1分布式卷
      • 3.1.2分布式卷的特点
      • 3.1.3创建分布式卷
    • 3.2条带卷
      • 3.2.1条带卷
      • 3.2.2条带卷的特点
      • 3.2.3创建条带卷
    • 3.3复制卷
      • 3.3.1复制卷
      • 3.3.2复制卷的特点
      • 3.3.3创建复制卷
    • 3.4分布式条带卷
      • 3.4.1分布式条带卷的特点
      • 3.4.2创建分布式条带卷
    • 3.5分布式复制卷
      • 3.5.1分布式复制卷的特点
      • 3.5.2创建分布式复制卷
  • 四 实验环境
  • 五 环境搭建
  • 六 创建卷
  • 七 部署客户端,创建测试文件
  • 八 破坏性测试
  • 九 其他的维护命令

一 GlusterFS概述

1.1 GlusterFS简介

●开源的分布式文件系统
●由存储服务器,客户端以及NFS/Samba存储网关组成
●无元数据服务器

1.2 GlusterFS特点

●扩展性和高性能
●高可用性
●全局统一命名空间
●弹性卷管理
●基于标准协议

1.3 模块化堆栈式架构

●模块化,堆栈式的架构
●通过对模块的组合,实现复杂的功能d

二 GlusterFS工作原理

2.1 GLusterFS工作流程

在这里插入图片描述
说明:
●Application:客户端或应用程序通过GlusterFS的挂载点访问数据
●VFS:linux系统内核
●FLUS-/dev/flus:VFS将数据递交给FUSE内核文件系统,fuse文件系统则是将数据通过/dev/fuse设备文件递交给了GLusterFS client端
●GLusterFS client:GLusterFS client收到数据后,client根据配置文件的配置对数据进行处理
●GlusterFS server:通过网路将数据传递至远端的GlusterFS Server,并且将数据写入到服务器存储设备上

2.2 弹性HASH算法

●通过HASH算法得到一个32位的整数
●划分为N个连续的子空间,每个空间对应一个Brick
●弹性HASH算法的优点:

  1. 保证数据平均分布在每一个Brick中
  2. 解决了对元数据服务器的依赖,进而解决了单点故障以及访问瓶颈

三 GlusterFS的卷类型

●分布式卷
●条带卷
●复制卷
●分布式条带卷
●分布式复制卷
●条带复制卷
●分布式条带复制卷

3.1分布式卷

3.1.1分布式卷

●没有对文件进行分块处理
●通过扩展文件属性保存HASH值
●支持的底层文件系统有EXT3,EXT4,ZFS,XFS等

3.1.2分布式卷的特点

●文件分布在不同的服务器,不具备冗余性
●更容易和廉价地扩展卷的大小
●单点故障会造成数据丢失
●依赖底层的数据保护

3.1.3创建分布式卷

●创建一个名为dis-volume的分布式卷,文件将根据HASH分布在server1:/dir1,server2:/dir2和server3:/dir3中

#gluster volume create die-volume server1:/dir1 server2:/dir2 server3:/dir3

3.2条带卷

3.2.1条带卷

●根据偏移量将文件分成N块(N个条带节点),轮询的存储在每个Brick Server节点
●存储大文件时,性能尤为突出
●不具备冗余性,类似Raid0

3.2.2条带卷的特点

●数据被分割成更小块分布到块服务器中的不同条带区
●分布减少了负载且更小的文件加速了存取的速度
●没有数据冗余

3.2.3创建条带卷

● 创建了一个名为Strip-volume的条带卷,文件将被分块轮询的存储在Server1:/dir1和Server2:/dir2两个Brick中

# gluster volume create stripe-volume stripe 2 transport tcp server1:/dir1 server2:/dir2

3.3复制卷

3.3.1复制卷

●同一文件保存一份或多份副本
●因为要保存副本,所以磁盘利用率较低
● 若多个节点上的存储空间不一致,将安照木桶效应取最低节点的容量作为该卷的总容量

3.3.2复制卷的特点

●卷中所有的服务器均保存一个完整的副本
●卷的副本数量可由客户创建的时候决定
●至少有两个块服务器或更多服务器
●具备冗余性

3.3.3创建复制卷

●创建名为rep-volume的复制卷,文件将同时存储两个副本,分别在Server1:/dir1和Server2:/dir2两个Brick中

# gluster volume create rep-volume replica 2 transport tcp server1:/dir1 server2:/dir2

3.4分布式条带卷

3.4.1分布式条带卷的特点

●兼顾分布式卷和条带卷的功能
●主要用于大文件访问处理
●至少最少需要4台服务器

3.4.2创建分布式条带卷

● 创建了名为dis-stripe的分布式条带卷,配置分布式的条带卷时,卷中Brick所包含的存储服务器数必须是条带数的倍数(>=2倍)

# gluster volume create dis-stripe stripe 2 transport tcp server1:/dir1 server2:/dir2 server3:/dir3 server4:/dir4

3.5分布式复制卷

3.5.1分布式复制卷的特点

●兼顾分布式卷和复制卷的功能
●用于需要冗余的情况

3.5.2创建分布式复制卷

● 创建名为dis-rep的分布式复制卷,额皮质分布式复制卷时,卷中Brick所包含的存储服务器数必须是复制卷的倍数(>=2倍)

# gluster volume create dis-rep replica 2 transport tcp server1:/dir1 server2:/dir2 server3:/dir3 server4:/dir4

四 实验环境

操作系统IP主机名硬盘数量
centos7.420.0.0.11node1sdb:20G sdc:20G sdd:20G sde:20G
centos7.420.0.0.12node2sdb:20G sdc:20G sdd:20G sde:20G
centos7.420.0.0.13node3sdb:20G sdc:20G sdd:20G sde:20G
centos7.420.0.0.15node4sdb:20G sdc:20G sdd:20G sde:20G

五 环境搭建

1.闭防火墙,核心防护
[root@localhost ~]# systemctl stop firewalld   
[root@localhost ~]# setenforce 02.修改主机名
[root@localhost ~]# hostnamectl set-hostname node1
[root@localhost ~]# hostnamectl set-hostname node2
[root@localhost ~]# hostnamectl set-hostname node3
[root@localhost ~]# hostnamectl set-hostname node4
[root@localhost ~]# su3.域名解析
[root@node1 ~]# vi /etc/hosts
20.0.0.11       node1
20.0.0.12       node2
20.0.0.13       node3
20.0.0.15       node4scp /etc/hosts root@20.0.0.12:/etc/hosts
scp /etc/hosts root@20.0.0.13:/etc/hosts
scp /etc/hosts root@20.0.0.15:/etc/hosts4.写脚本,创建磁盘分区
##在四台服务器上添加4块新硬盘##
[root@node1 ~]# vi disk.sh
#!/bin/bash
echo "the disks exist list:"
fdisk -l | grep '磁盘 /dev/sd[a-z]'
echo "================================"
PS3="chose which disk you want to create:"
select VAR in `ls /dev/sd* | grep -o 'sd[b-z]' | uniq` quit
docase $VAR insda)fdisk -l /dev/sdabreak ;;sd[b-z])#create partitionsecho "npw" | fdisk /dev/$VAR#make filesystemmkfs.xfs -i size=512 /dev/${VAR}"1" &> /dev/null#mount the systemmkdir -p /data/${VAR}"1" &> /dev/nullecho -e  "/dev/${VAR}"1"      /data/${VAR}"1" xfs     defaults 0 0\n" >> /etc/fstabmount -a &> /dev/nullbreak ;;quit)break;;*)echo "wrong disk,please check again";;esac
done
[root@node1 ~]# chmod +x disk.sh[root@node1 ~]# ./disk.sh                                    //分别输入1,2,3,4创建磁盘分区
the disks exist list:
================================
1) sdb
2) sdc
3) sdd
4) sde
5) quit[root@node1 ~]# df -Th
/dev/sdb1      xfs        20G   33M   20G   1% /data/sdb1
/dev/sdc1      xfs        20G   33M   20G   1% /data/sdc1
/dev/sdd1      xfs        20G   33M   20G   1% /data/sdd1
/dev/sde1      xfs        20G   33M   20G   1% /data/sde1##其他三台服务器复制脚步操作##
[root@node1 ~]# scp disk.sh root@20.0.0.12:/root
[root@node1 ~]# scp disk.sh root@20.0.0.13:/root
[root@node1 ~]# scp disk.sh root@20.0.0.15:/root5.搭建GFS本源
##把GFS本地源文件夹传到/abc目录下
[root@node1 abc]# cd /etc/yum.repos.d/
[root@node1 yum.repos.d]# mv backup/ backup.bak/
[root@node1 yum.repos.d]# vi GLFS.repo
[GLFS]
name=glfs
baseurl=file:///abc/gfsrepo/
gpgcheck=0
enabled=1
[root@node1 yum.repos.d]# yum -y install glusterfs-server glusterfs-fuse glusterfs-rdma[root@node1 yum.repos.d]# systemctl start glusterd.service
[root@node1 yum.repos.d]# systemctl enable glusterd.service
Created symlink from /etc/systemd/system/multi-user.target.wants/glusterd.service to /usr/lib/systemd/system/glusterd.service.
[root@node1 yum.repos.d]# systemctl status glusterd.service##其他三个同理##
[root@node2 ~]# mkdir /abc/gfsrepo/
[root@node3 ~]# mkdir /abc/gfsrepo/
[root@node4 ~]# mkdir /abc/gfsrepo/
[root@node1 abc]# scp -r /abc/gfsrepo/ root@20.0.0.12:/abc/
[root@node1 abc]# scp -r /abc/gfsrepo/ root@20.0.0.13:/abc/
[root@node1 abc]# scp -r /abc/gfsrepo/ root@20.0.0.15:/abc/6.设置时间同步
[root@node1 ~]# yum -y install ntpdate
[root@node1 ~]# ntpdate ntp1.aliyun.com7.添加入存储信任池,只要在一台主机上添加其他节点即可
[root@node1 ~]# gluster peer probe node2
peer probe: success. 
[root@node1 ~]# gluster peer probe node3
peer probe: success. 
[root@node1 ~]# gluster peer probe node4
peer probe: success. [root@node1 ~]# gluster peer status
Number of Peers: 3Hostname: node2
Uuid: b1c2d15a-97bd-4c10-a1d3-13f0bb2a8a10
State: Peer in Cluster (Connected)Hostname: node3
Uuid: e5e99a92-4001-42a8-b958-71f6bd8ae3f0
State: Peer in Cluster (Connected)Hostname: node4
Uuid: a9059dfe-8254-4ab2-80be-3fac9e167e74
State: Peer in Cluster (Connected)

六 创建卷

1.分布式卷
[root@node1 ~]# gluster volume create dis-vol node1:/data/sdb1 node2:/data/sdb1 force
volume create: dis-vol: success: please start the volume to access data
[root@node1 ~]# gluster volume info dis-volVolume Name: dis-vol
Type: Distribute
Volume ID: b1256331-2191-4a5d-8392-9acc3a978684
Status: Created
Snapshot Count: 0
Number of Bricks: 2
Transport-type: tcp
Bricks:
Brick1: node1:/data/sdb1
Brick2: node2:/data/sdb1
Options Reconfigured:
transport.address-family: inet
nfs.disable: on
[root@node1 ~]# gluster volume start dis-vol
volume start: dis-vol: success
[root@node1 ~]# gluster volume info dis-volVolume Name: dis-vol
Type: Distribute
Volume ID: b1256331-2191-4a5d-8392-9acc3a978684
Status: Started
Snapshot Count: 0
Number of Bricks: 2
Transport-type: tcp
Bricks:
Brick1: node1:/data/sdb1
Brick2: node2:/data/sdb1
Options Reconfigured:
transport.address-family: inet
nfs.disable: on2.条带卷
[root@node1 ~]# gluster volume create stripe-vol stripe 2 node1:/data/sdc1 node2:/data/sdc1 force
volume create: stripe-vol: success: please start the volume to access data
[root@node1 ~]# gluster volume start stripe-vol
volume start: stripe-vol: success
[root@node1 ~]# gluster volume info stripe-volVolume Name: stripe-vol
Type: Stripe
Volume ID: 4cfef65d-1193-495a-8d00-c8c8f14e6f53
Status: Started
Snapshot Count: 0
Number of Bricks: 1 x 2 = 2
Transport-type: tcp
Bricks:
Brick1: node1:/data/sdc1
Brick2: node2:/data/sdc1
Options Reconfigured:
transport.address-family: inet
nfs.disable: on3.复制卷
[root@node1 ~]# gluster volume create rep-vol replica 2 node3:/data/sdd1 node4:/data/sdd1 force
volume create: rep-vol: success: please start the volume to access data
[root@node1 ~]# gluster volume info rep-volVolume Name: rep-vol
Type: Replicate
Volume ID: 1db5498e-d27d-4886-8d67-c4a31ccc3295
Status: Started
Snapshot Count: 0
Number of Bricks: 1 x 2 = 2
Transport-type: tcp
Bricks:
Brick1: node3:/data/sdd1
Brick2: node4:/data/sdd1
Options Reconfigured:
transport.address-family: inet
nfs.disable: on4.分布式条带卷
[root@node1 ~]# gluster volume create dis-stripe stripe 2 node1:/data/sdd1 node2:/data/sdd1 node3:/data/sdb1 node4:/data/sdb1 force
volume create: dis-stripe: success: please start the volume to access data
[root@node1 ~]# gluster volume start dis-stripe
volume start: dis-stripe: success
[root@node1 ~]# gluster volume info dis-stripeVolume Name: dis-stripe
Type: Distributed-Stripe
Volume ID: 78843c3a-eb16-408c-9dc5-3565d50f4a8a
Status: Started
Snapshot Count: 0
Number of Bricks: 2 x 2 = 4
Transport-type: tcp
Bricks:
Brick1: node1:/data/sdd1
Brick2: node2:/data/sdd1
Brick3: node3:/data/sdb1
Brick4: node4:/data/sdb1
Options Reconfigured:
transport.address-family: inet
nfs.disable: on5.分布式复制卷
[root@node1 ~]# gluster volume create dis-rep replica 2 node1:/data/sde1 node2:/data/sde1 node3:/data/sde1 node4:/data/sde1 force
volume create: dis-rep: success: please start the volume to access data
[root@node1 ~]# gluster volume start dis-rep
volume start: dis-rep: success
[root@node1 ~]# gluster volume info dis-repVolume Name: dis-rep
Type: Distributed-Replicate
Volume ID: 5d9a0b1c-f7a9-41b5-80dc-1f366b180674
Status: Started
Snapshot Count: 0
Number of Bricks: 2 x 2 = 4
Transport-type: tcp
Bricks:
Brick1: node1:/data/sde1
Brick2: node2:/data/sde1
Brick3: node3:/data/sde1
Brick4: node4:/data/sde1
Options Reconfigured:
transport.address-family: inet
nfs.disable: on

七 部署客户端,创建测试文件

1.搭建GFS本地源
[root@node1 ~]# scp -r /abc/gfsrepo/ root@20.0.0.21:/abc/[root@localhost abc]# cd /etc/yum.repos.d/
[root@localhost yum.repos.d]# mv backup/ backup.bak/
[root@localhost yum.repos.d]# vi GLFS.repo
[GLFS]
name=glfs
baseurl=file:///abc/gfsrepo
gpgcheck=0
enabled=12.域名解析
[root@localhost yum.repos.d]# vi /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
20.0.0.11       node1
20.0.0.12       node2
20.0.0.13       node3
20.0.0.15       node43.挂载
##挂载分布式卷##
[root@localhost yum.repos.d]# mount.glusterfs node1:dis-vol /test/dis/
[root@localhost yum.repos.d]# df -Th
Filesystem     Type            Size  Used Avail Use% Mounted on
/dev/sda3      xfs              50G  4.1G   46G   9% /
devtmpfs       devtmpfs        3.8G     0  3.8G   0% /dev
tmpfs          tmpfs           3.9G     0  3.9G   0% /dev/shm
tmpfs          tmpfs           3.9G   13M  3.8G   1% /run
tmpfs          tmpfs           3.9G     0  3.9G   0% /sys/fs/cgroup
/dev/sda5      xfs             242G   37M  241G   1% /home
/dev/sda1      xfs            1014M  174M  841M  18% /boot
tmpfs          tmpfs           781M   12K  781M   1% /run/user/42
tmpfs          tmpfs           781M     0  781M   0% /run/user/0
/dev/sr0       iso9660         4.3G  4.3G     0 100% /mnt
node1:dis-vol  fuse.glusterfs   40G   65M   40G   1% /test/dis##挂载条带卷##
[root@localhost yum.repos.d]# mkdir -p /test/stripe
[root@localhost yum.repos.d]# mount.glusterfs node1:stripe-vol /test/stripe/
[root@localhost yum.repos.d]# df -Th
Filesystem       Type            Size  Used Avail Use% Mounted on
/dev/sda3        xfs              50G  4.1G   46G   9% /
devtmpfs         devtmpfs        3.8G     0  3.8G   0% /dev
tmpfs            tmpfs           3.9G     0  3.9G   0% /dev/shm
tmpfs            tmpfs           3.9G   13M  3.8G   1% /run
tmpfs            tmpfs           3.9G     0  3.9G   0% /sys/fs/cgroup
/dev/sda5        xfs             242G   37M  241G   1% /home
/dev/sda1        xfs            1014M  174M  841M  18% /boot
tmpfs            tmpfs           781M   12K  781M   1% /run/user/42
tmpfs            tmpfs           781M     0  781M   0% /run/user/0
/dev/sr0         iso9660         4.3G  4.3G     0 100% /mnt
node1:dis-vol    fuse.glusterfs   40G   65M   40G   1% /test/dis
node1:stripe-vol fuse.glusterfs   40G   65M   40G   1% /test/stripe##挂载复制卷##
[root@localhost yum.repos.d]# mkdir -p /test/rep
[root@localhost yum.repos.d]# mount.glusterfs node3:rep-vol /test/rep/
[root@localhost yum.repos.d]# df -Th
Filesystem       Type            Size  Used Avail Use% Mounted on
/dev/sda3        xfs              50G  4.1G   46G   9% /
devtmpfs         devtmpfs        3.8G     0  3.8G   0% /dev
tmpfs            tmpfs           3.9G     0  3.9G   0% /dev/shm
tmpfs            tmpfs           3.9G   13M  3.8G   1% /run
tmpfs            tmpfs           3.9G     0  3.9G   0% /sys/fs/cgroup
/dev/sda5        xfs             242G   37M  241G   1% /home
/dev/sda1        xfs            1014M  174M  841M  18% /boot
tmpfs            tmpfs           781M   12K  781M   1% /run/user/42
tmpfs            tmpfs           781M     0  781M   0% /run/user/0
/dev/sr0         iso9660         4.3G  4.3G     0 100% /mnt
node1:dis-vol    fuse.glusterfs   40G   65M   40G   1% /test/dis
node1:stripe-vol fuse.glusterfs   40G   65M   40G   1% /test/stripe
node3:rep-vol    fuse.glusterfs   20G   33M   20G   1% /test/rep##挂载分布式条带卷##
[root@localhost yum.repos.d]# mkdir -p /test/dis-stripe
[root@localhost yum.repos.d]# mount.glusterfs node1:dis-stripe /test/dis-stripe/
[root@localhost yum.repos.d]# df -TH
Filesystem       Type            Size  Used Avail Use% Mounted on
/dev/sda3        xfs              54G  4.4G   50G   9% /
devtmpfs         devtmpfs        4.1G     0  4.1G   0% /dev
tmpfs            tmpfs           4.1G     0  4.1G   0% /dev/shm
tmpfs            tmpfs           4.1G   13M  4.1G   1% /run
tmpfs            tmpfs           4.1G     0  4.1G   0% /sys/fs/cgroup
/dev/sda5        xfs             259G   38M  259G   1% /home
/dev/sda1        xfs             1.1G  183M  881M  18% /boot
tmpfs            tmpfs           819M   13k  819M   1% /run/user/42
tmpfs            tmpfs           819M     0  819M   0% /run/user/0
/dev/sr0         iso9660         4.6G  4.6G     0 100% /mnt
node1:dis-vol    fuse.glusterfs   43G   68M   43G   1% /test/dis
node1:stripe-vol fuse.glusterfs   43G   68M   43G   1% /test/stripe
node3:rep-vol    fuse.glusterfs   22G   34M   22G   1% /test/rep
node1:dis-stripe fuse.glusterfs   86G  136M   86G   1% /test/dis-stripe##挂载分布式复制卷##
[root@localhost yum.repos.d]# mkdir -p /test/dis-rep
[root@localhost yum.repos.d]# mount.glusterfs node1:dis-rep /test/dis-rep/
[root@localhost yum.repos.d]# df -Th
Filesystem       Type            Size  Used Avail Use% Mounted on
/dev/sda3        xfs              50G  4.1G   46G   9% /
devtmpfs         devtmpfs        3.8G     0  3.8G   0% /dev
tmpfs            tmpfs           3.9G     0  3.9G   0% /dev/shm
tmpfs            tmpfs           3.9G   13M  3.8G   1% /run
tmpfs            tmpfs           3.9G     0  3.9G   0% /sys/fs/cgroup
/dev/sda5        xfs             242G   37M  241G   1% /home
/dev/sda1        xfs            1014M  174M  841M  18% /boot
tmpfs            tmpfs           781M   12K  781M   1% /run/user/42
tmpfs            tmpfs           781M     0  781M   0% /run/user/0
/dev/sr0         iso9660         4.3G  4.3G     0 100% /mnt
node1:dis-vol    fuse.glusterfs   40G   65M   40G   1% /test/dis
node1:stripe-vol fuse.glusterfs   40G   65M   40G   1% /test/stripe
node3:rep-vol    fuse.glusterfs   20G   33M   20G   1% /test/rep
node1:dis-stripe fuse.glusterfs   80G  130M   80G   1% /test/dis-stripe
node1:dis-rep    fuse.glusterfs   40G   65M   40G   1% /test/dis-rep4.创建测试文件
##创建5个40M的文件##
[root@localhost yum.repos.d]# dd if=/dev/zero of=/demo1.log bs=1M count=40
[root@localhost yum.repos.d]# dd if=/dev/zero of=/demo2.log bs=1M count=40
[root@localhost yum.repos.d]# dd if=/dev/zero of=/demo3.log bs=1M count=40
[root@localhost yum.repos.d]# dd if=/dev/zero of=/demo4.log bs=1M count=40
[root@localhost yum.repos.d]# dd if=/dev/zero of=/demo5.log bs=1M count=40##复制5个文件到不同卷上##
[root@localhost /]# cp /demo* /test/dis
[root@localhost /]# cp /demo* /test/stripe
[root@localhost /]# cp /demo* /test/rep
[root@localhost /]# cp /demo* /test/dis-stripe
[root@localhost /]# cp /demo* /test/dis-rep##查看##
[root@localhost /]# cd /test/
[root@localhost test]# ll
total 20
drwxr-xr-x 3 root root 4096 Oct 27 17:38 dis
drwxr-xr-x 3 root root 4096 Oct 27 17:39 dis-rep
drwxr-xr-x 3 root root 4096 Oct 27 17:39 dis-stripe
drwxr-xr-x 3 root root 4096 Oct 27 17:38 rep
drwxr-xr-x 3 root root 4096 Oct 27 17:38 stripe

八 破坏性测试

##关闭node2查看文件##
[ro[root@localhost test]# ls -lh dis
total 160M
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo1.log
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo2.log
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo3.log
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo4.log[root@localhost test]# ls -lh dis-rep
total 200M
-rw-r--r-- 1 root root 40M Oct 27 17:39 demo1.log
-rw-r--r-- 1 root root 40M Oct 27 17:39 demo2.log
-rw-r--r-- 1 root root 40M Oct 27 17:39 demo3.log
-rw-r--r-- 1 root root 40M Oct 27 17:39 demo4.log
-rw-r--r-- 1 root root 40M Oct 27 17:39 demo5.log[root@localhost test]# ls -lh dis-stripe
total 40M
-rw-r--r-- 1 root root 40M Oct 27 17:39 demo5.log[root@localhost test]# ls -lh stripe
ls: reading directory stripe: Transport endpoint is not connected
total 0##关闭node3查看文件##
[root@localhost test]# ls -lh rep
total 200M
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo1.log
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo2.log
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo3.log
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo4.log
-rw-r--r-- 1 root root 40M Oct 27 17:38 demo5.log

九 其他的维护命令

1.删除卷
[root@node1 ~]# gluster volume stop rep-vol
Stopping volume will make its data inaccessible. Do you want to continue? (y/n) yes
volume stop: rep-vol: success
[root@node1 ~]# gluster volume list 
dis-rep
dis-stripe
dis-vol
rep-vol
stripe-vol
[root@node1 ~]# gluster volume delete rep-vol              //删除卷时,信任池中不能有主机处于宕机状态,否则删除不成功2.访问控制
[root@node1 ~]# gluster volume set dis-vol auth.reject 20.0.0.12
volume set: success                                 //仅拒绝[root@node1 ~]# gluster volume set dis-vol auth.allow 20.0.0.12
volume set: success                                //仅允许

这篇关于理论+实验 详解GFS分布式文件系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/742010

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

嵌入式Openharmony系统构建与启动详解

大家好,今天主要给大家分享一下,如何构建Openharmony子系统以及系统的启动过程分解。 第一:OpenHarmony系统构建      首先熟悉一下,构建系统是一种自动化处理工具的集合,通过将源代码文件进行一系列处理,最终生成和用户可以使用的目标文件。这里的目标文件包括静态链接库文件、动态链接库文件、可执行文件、脚本文件、配置文件等。      我们在编写hellowor

LabVIEW FIFO详解

在LabVIEW的FPGA开发中,FIFO(先入先出队列)是常用的数据传输机制。通过配置FIFO的属性,工程师可以在FPGA和主机之间,或不同FPGA VIs之间进行高效的数据传输。根据具体需求,FIFO有多种类型与实现方式,包括目标范围内FIFO(Target-Scoped)、DMA FIFO以及点对点流(Peer-to-Peer)。 FIFO类型 **目标范围FIFO(Target-Sc

019、JOptionPane类的常用静态方法详解

目录 JOptionPane类的常用静态方法详解 1. showInputDialog()方法 1.1基本用法 1.2带有默认值的输入框 1.3带有选项的输入对话框 1.4自定义图标的输入对话框 2. showConfirmDialog()方法 2.1基本用法 2.2自定义按钮和图标 2.3带有自定义组件的确认对话框 3. showMessageDialog()方法 3.1

脏页的标记方式详解

脏页的标记方式 一、引言 在数据库系统中,脏页是指那些被修改过但还未写入磁盘的数据页。为了有效地管理这些脏页并确保数据的一致性,数据库需要对脏页进行标记。了解脏页的标记方式对于理解数据库的内部工作机制和优化性能至关重要。 二、脏页产生的过程 当数据库中的数据被修改时,这些修改首先会在内存中的缓冲池(Buffer Pool)中进行。例如,执行一条 UPDATE 语句修改了某一行数据,对应的缓