主頁 > 資料庫 > 大點干!早點散----------深入剖析GFS分布式檔案系統

大點干!早點散----------深入剖析GFS分布式檔案系統

2020-09-16 18:47:45 資料庫

文章目錄

  • 一、GlusterFS(GFS)介紹
    • 1、GlusterFS
    • 2、GlusterFS特點
    • 3、常用術語
    • 4、GFS的結構
    • 5、彈性HASH演算法
    • 6、GlusterFS作業原理
  • 二、GlusterFS的卷型別
    • 1、分布式卷
    • 2、條帶卷
    • 3、復制卷
    • 4、分布式條帶卷
    • 5、分布式復制卷
    • 6、條帶復制卷
    • 7、分布式條帶復制卷
  • 三、GFS平臺部署
    • 1、實驗環境
    • 2、磁盤磁區、掛載
    • 3、配置yum本地源,安裝環境包
    • 4、同步時間,添加到存盤信任池
    • 5、分布式卷的建立與查看
    • 6、客戶機的環境搭建,并掛載分布式卷
    • 7、分布式卷的檔案存盤測驗
    • 8、 條帶卷的創建與測驗
    • 9、復制卷的創建與測驗
    • 10、 分布式條帶卷的創建與測驗
    • 11、分布式復制卷

一、GlusterFS(GFS)介紹

1、GlusterFS

Gluster File System,開源的分布式檔案系統,是Scale存盤的核心,能夠處理千數量級的客戶端.在傳統的解決 方案中Glusterfs能夠靈活的結合物理的,虛擬的和云資源去體現高可用和企業級的性能存盤
由存盤服務器(Brick Server)、客戶端以及NFS/Samba 存盤網關組成
無元資料服務器
在這里插入圖片描述
RDMA 的介紹
RDMA 是通過網路把資料直接傳入計算機的存盤區,將資料從一個系統快速移動到遠程系統存盤器中,而不對作業系統造成任何影響

普通網卡的作業程序如下:先把收到的資料包快取到系統上,資料包經過處理后,相應資料被分配到一個TCP 連接;然后,接收系統再把主動提供的TCP 資料同相應的應用程式聯系起來,并將資料從系統緩沖區拷貝到目標存盤地址.這樣,制約網路速率的因素就出現了

2、GlusterFS特點

擴展性和高性能
高可用性
全域統一命名空間
彈性卷管理
基于標準協議

3、常用術語

Brick:GFS中的存盤單元,通過是一個受信存盤池中的服務器的一個匯出目錄,可以通過主機名和目錄名來標識,如’SERVER:EXPORT’
Volume:卷
FUSE:內核檔案系統,Filesystem Userspace是一個可加載的內核模塊,其支持非特權用戶創建自己的檔案系統而不需要修改內核代碼,通過在用戶空間運行檔案系統的代碼通過FUSE代碼與內核進行橋接,
VFS:虛擬檔案系統
Glusterd:Gluster management daemon,要在trusted storage pool中所有的服務器上運行,

4、GFS的結構

  • 模塊化堆疊式架構
  • 模塊化、堆疊式的架構
  • 通過對模塊的組合,實作復雜的功能

5、彈性HASH演算法

  • 通過HASH演算法得到一個32位的整數
  • 劃分為N個連續的子空間,每個空間對應一個Brick
  • 彈性HASH演算法的優點
    保證資料平均分布在每一個Brick中
    解決了對元資料服務器的依賴,進而解決了單點故障以及訪問瓶頸

6、GlusterFS作業原理

1、客戶端或應用程式通過GlusterFS的掛載點訪問資料
2、linux系統內核通過VFS API收到請求并處理
3、VFS將資料遞交給FUSE內核檔案系統, fuse檔案系統則是將資料通過/dev/fuse設備檔案遞交給了GlusterFS client端
4、GlusterFS client 收到資料后,client根據組態檔的配置對資料進行處理
5、通過網路將資料傳遞至遠端的GlusterFS Server,并且將資料寫入到服務器存盤設備上

在這里插入圖片描述

二、GlusterFS的卷型別

1、分布式卷

分布式卷是 GlusterFS 的默認卷,在創建卷時,默認選項是創建分布式卷,在該模式下, 并沒有對檔案進行分塊處理,檔案直接存盤在某個 Server 節點上,直接使用本地檔案系統 進行檔案存盤,大部分 Linux 命令和工具可以繼續正常使用,需要通過擴展檔案屬性保存 HASH 值,目前支持的底層檔案系統有 EXT3、EXT4、ZFS、XFS 等, 由于使用的是本地檔案系統,所以存取效率并沒有提高,反而會因為網路通信的原因而 有所降低;另外支持超大型檔案也會有一定的難度,因為分布式卷不會對檔案進行分塊處理, 雖然 EXT4 已經可以支持最大 16TB 的單個檔案,但是本地存盤設備的容量實在有限,File1 和 File2 存放在 Server1,而 File3 存放在 Server2,檔案都是隨機存盤,一 個檔案(如 File1)要么在 Server1 上,要么在 Server2 上,不能分塊同時存放在 Server1 和 Server2 上,
在這里插入圖片描述
分布式卷具有如下特點:

  • 檔案分布在不同的服務器,不具備冗余性,
  • 更容易且廉價地擴展卷的大小,
  • 存在單點故障會造成資料丟失,
  • 依賴底層的資料保護

2、條帶卷

根據偏移量將檔案分成N塊(N個條帶節點),輪詢的存盤在每個Brick Server節點
存盤大檔案時,性能尤為突出
不具備冗余性,類似Raid0
在這里插入圖片描述

3、復制卷

相當于 RAID1,即同一檔案保存一份 或多份副本,每個節點上保存相同的內容和目錄結構,復制模式因為要保存副本,所以磁盤 利用率較低,如果多個節點上的存盤空間不一致,那么將按照木桶效應取最低節點的容量作為該卷的總容量,在配置復制卷時,復制數必須等于卷中 Brick 所包含的存盤服務器數,復 制卷具備冗余性,即使一個節點損壞,也不影響資料的正常使用
在這里插入圖片描述

4、分布式條帶卷

File1和File2通過分布式卷的功能分別定位到Server1 和 Server2,在 Server1 中,File1 被分割成 4 段,其中 1、3 在 Server1 中的 exp1 目錄中, 2、4 在 Server1 中的 exp2 目錄中,在 Server2 中,File2 也被分割成 4 段,其中 1、3 在 Server2 中的 exp3 目錄中,2、4 在 Server2 中的 exp4 目錄中,
在這里插入圖片描述

5、分布式復制卷

分布式復制卷兼顧分布式卷和復制卷的功能,主要用于需要冗余的情況下,File1 和 File2 通過分布式卷的功能分別定位到 Server1 和 Server2, 在存放 File1 時,File1 根據復制卷的特性,將存在兩個相同的副本,分別是 Server1 中的 exp1 目錄和 Server2 中的 exp2 目錄,在存放 File2 時,File2 根據復制卷的特性,也將存 在兩個相同的副本,分別是 Server3 中的 exp3 目錄和 Server4 中的 exp4 目錄,
在這里插入圖片描述

6、條帶復制卷

首先觸發條帶卷的功能,將資料等分成4份,輪詢存放 ,然后輪詢后再進行觸發復制卷的作用,進行復制
在這里插入圖片描述

7、分布式條帶復制卷

聯想一下上面的條帶復制卷,懶得畫了

三、GFS平臺部署

1、實驗環境

實驗引數
VMware軟體
一臺centos7虛擬機,IP地址為:14.0.0.7,主機名為:node1,添加4塊磁盤,分別都為20G

一臺centos7虛擬機,IP地址為:14.0.0.110,主機名為:node2,添加4塊磁盤,分別都為20G

一臺centos7虛擬機,IP地址為:14.0.0.111,主機名為:node3,添加4塊磁盤,分別都為20G

一臺centos7虛擬機,IP地址為:14.0.0.112,主機名為:node4,添加4塊磁盤,分別都為20G

一臺centos7虛擬機,IP地址為:14.0.0.177,主機名為:client,當做測驗機使用

2、磁盤磁區、掛載

在四臺node節點服務器上,編輯腳本自動進行磁區,以node1界定啊服務器為例子,

[root@localhost ~]# systemctl stop firewalld.service 
[root@localhost ~]# setenforce 0
[root@node1 ~]# cd /opt
[root@node1 opt]# vim fdisk.sh
#!bin/bash
for disk in `fdisk -l |grep -o 'sd[b-z]'| uniq |awk 'BEGIN{ORS=" "} {print $0 }'`
do
     echo "n
           p
                
                
           
           w"| fdisk /dev/$disk
mkfs.xfs -i size=512 /dev/${disk}"1" &> /dev/null
 mkdir -p /data/${disk}"1" &> /dev/null
echo -e "/dev/${disk}"1" /data/${disk}"1" xfs defaults 0 0\n" >> /etc/fstab
  mount -a &> /dev/null
done
[root@node1 opt]# chmod +x fdisk.sh 
[root@node1 opt]# sh fdisk.sh
[root@node1 opt]# df -hT
檔案系統                型別      容量  已用  可用 已用% 掛載點
/dev/mapper/centos-root xfs        15G  3.8G   12G   26% /
devtmpfs                devtmpfs  1.9G     0  1.9G    0% /dev
tmpfs                   tmpfs     1.9G     0  1.9G    0% /dev/shm
tmpfs                   tmpfs     1.9G   13M  1.9G    1% /run
tmpfs                   tmpfs     1.9G     0  1.9G    0% /sys/fs/cgroup
/dev/sda1               xfs       2.0G  179M  1.9G    9% /boot
/dev/mapper/centos-home xfs        25G   33M   25G    1% /home
tmpfs                   tmpfs     378M   12K  378M    1% /run/user/42
tmpfs                   tmpfs     378M     0  378M    0% /run/user/0
/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

其余三個幾點配置一樣,這里就不一一介紹了

3、配置yum本地源,安裝環境包

在所有的節點服務器上操作(以node1服務器為例,其他三臺一樣的操作),將gluster的rpm環境包拷貝進當前目錄下

[root@node1 opt]# cd ~
[root@node1 ~]# ls
anaconda-ks.cfg  initial-setup-ks.cfg  模板  圖片  下載  桌面
gfsrepo          公共                  視頻  檔案  音樂
[root@node1 ~]# mkdir /opt/gfs
[root@node1 ~]# mv gfsrepo/ /opt/gfs/
[root@node1 ~]# cd /etc/yum.repos.d/
[root@node1 yum.repos.d]# mkdir bak
[root@node1 yum.repos.d]# mv C* bak/
[root@node1 yum.repos.d]# ls
bak
[root@node1 yum.repos.d]# vim GLFS.repo
[GLFS]
name=glfs
baseurl=file:///opt/gfs/gfsrepo
gpgcheck=0
enabled=1
[root@node1 yum.repos.d]# yum list    ##加載一下
[root@node1 yum.repos.d]# yum remove glusterfs-client-xlators.x86_64 glusterfs glusterfs-libs -y   ##因為centos7中默認已經安裝了部分依賴包,版本比yum源的版本高,所以先將這些軟體包卸載,再進行安裝,否則報錯,
[root@node1 yum.repos.d]# yum install glusterfs-server glusterfs-fuse glusterfs-rdma -y    ##安裝gluster環境依賴包
[root@node1 yum.repos.d]# systemctl start glusterd.service    ##開啟glusterd服務
[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    ##查看服務狀態
 glusterd.service - GlusterFS, a clustered file-system server
   Loaded: loaded (/usr/lib/systemd/system/glusterd.service; enabled; vendor preset: disabled)
   Active: active (running) since  2020-09-14 12:17:11 CST; 40s ago
 Main PID: 13030 (glusterd)
   CGroup: /system.slice/glusterd.service
           └─13030 /usr/sbin/glusterd -p /var/run/glusterd.pid --log-level I...

9 14 12:17:11 node1 systemd[1]: Starting GlusterFS, a clustered file-sy.....
9 14 12:17:11 node1 systemd[1]: Started GlusterFS, a clustered file-sys...r.
Hint: Some lines were ellipsized, use -l to show in full.

4、同步時間,添加到存盤信任池

將時間同步與阿里云時間一樣

[root@node1 yum.repos.d]# ntpdate ntp1.aliyun.com
14 Sep 18:33:31 ntpdate[17167]: adjust time server 120.25.115.20 offset 0.003253 sec

[root@node2 ~]# ntpdate ntp1.aliyun.com
14 Sep 18:33:38 ntpdate[16974]: adjust time server 120.25.115.20 offset 0.001146 sec

[root@node3 ~]# ntpdate ntp1.aliyun.com
14 Sep 18:33:45 ntpdate[69222]: adjust time server 120.25.115.20 offset 0.001511 sec

[root@node4 gfs]# ntpdate ntp1.aliyun.com
14 Sep 18:33:04 ntpdate[13964]: adjust time server 120.25.115.20 offset 0.006495 sec

將node服務器添加到存盤信任池,在任何一個節點上添加就可以了,可以在任何一個節點上查看存盤信任池的狀態

[root@node1 yum.repos.d]# gluster peer probe node2
peer probe: success. 
[root@node1 yum.repos.d]# gluster peer probe node3
peer probe: success. 
[root@node1 yum.repos.d]# gluster peer probe node4
peer probe: success. 

[root@node1 yum.repos.d]# gluster peer status    ##查看gluster的地址池狀態
Number of Peers: 3

Hostname: node2
Uuid: 4abc4d2b-5e27-4dfc-b846-900b6d1860ad
State: Peer in Cluster (Connected)

Hostname: node3
Uuid: 2ae7b76b-aa30-43e9-ac47-5ef41c0ccf78
State: Peer in Cluster (Connected)

Hostname: node4
Uuid: dc4c1a0b-6b60-442a-a0ab-c4fff72677f3
State: Peer in Cluster (Connected)

5、分布式卷的建立與查看

這里使用node1和node2的sdb1硬碟來建立分布式卷,在任何一個節點服務器上都可以進行創建,在node3服務器上演示

[root@node3 ~]# 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@node3 ~]#  gluster volume list    ##查看卷串列
dis-vol
[root@node3 ~]#  gluster volume info dis-vol    ##查看分布式卷的詳細資訊
 
Volume Name: dis-vol
Type: Distribute
Volume ID: 1d3977d0-7b39-4455-ab3f-1c4d579934ff
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@node3 ~]#  gluster volume start dis-vol   ##開啟分布式卷
volume start: dis-vol: success

gluster volume stop dis-vol 關閉分布式卷
gluster volume delete dis-vol 洗掉分布式卷

6、客戶機的環境搭建,并掛載分布式卷

[root@localhost ~]# hostnamectl set-hostname client    ##改主機名
[root@localhost ~]# su
配置yum本地源
[root@client ~]# cd /etc/yum.repos.d/
[root@client yum.repos.d]# mkdir bak
[root@client yum.repos.d]# mv C* bak/
[root@client yum.repos.d]# vim GLFS.repo
[GLFS]
name=glfs
baseurl=file:///opt/gfs/gfsrepo
gpgcheck=0
enabled=1
[root@node3 ~]# yum list
[root@node1 yum.repos.d]# yum remove glusterfs-client-xlators.x86_64 glusterfs glusterfs-libs -y  
[root@node1 yum.repos.d]# yum install glusterfs-server glusterfs-fuse glusterfs-rdma -y 
[root@node1 yum.repos.d]# vim /etc/hosts
14.0.0.7 node1
14.0.0.110 node2
14.0.0.111 node3
14.0.0.112 node4

分布式卷掛載命令在client上進行輸入,可以掛載任何一個節點,都可以實作掛載

[root@client yum.repos.d]# mkdir -p /test/dis     ##創建掛載目錄
[root@client yum.repos.d]# mount.glusterfs node4:dis-vol /test/dis    ##實作掛載
[root@client yum.repos.d]# df -Th
檔案系統       型別            容量  已用  可用 已用% 掛載點
/dev/sda5      xfs              40G  4.9G   36G   13% /
devtmpfs       devtmpfs        895M     0  895M    0% /dev
tmpfs          tmpfs           910M     0  910M    0% /dev/shm
tmpfs          tmpfs           910M   11M  900M    2% /run
tmpfs          tmpfs           910M     0  910M    0% /sys/fs/cgroup
/dev/sda2      xfs              50G   33M   50G    1% /home
/dev/sda1      xfs             2.0G  174M  1.9G    9% /boot
tmpfs          tmpfs           182M  8.0K  182M    1% /run/user/42
tmpfs          tmpfs           182M   40K  182M    1% /run/user/0
/dev/sr0       iso9660         4.3G  4.3G     0  100% /run/media/root/CentOS 7 x86_64
node4:dis-vol  fuse.glusterfs   40G   65M   40G    1% /test/dis

7、分布式卷的檔案存盤測驗

創建5個大小為40M的的檔案

[root@client yum.repos.d]# dd if=/dev/zero of=/demo1.log bs=1M count=40
記錄了40+0 的讀入
記錄了40+0 的寫出
41943040位元組(42 MB)已復制,0.0391551 秒,1.1 GB/
[root@client yum.repos.d]# dd if=/dev/zero of=/demo2.log bs=1M count=40
記錄了40+0 的讀入
記錄了40+0 的寫出
41943040位元組(42 MB)已復制,0.230143 秒,182 MB/
[root@client yum.repos.d]# dd if=/dev/zero of=/demo3.log bs=1M count=40
記錄了40+0 的讀入
記錄了40+0 的寫出
41943040位元組(42 MB)已復制,0.66821 秒,62.8 MB/
[root@client yum.repos.d]# dd if=/dev/zero of=/demo4.log bs=1M count=40
記錄了40+0 的讀入
記錄了40+0 的寫出
41943040位元組(42 MB)已復制,0.867869 秒,48.3 MB/
[root@client yum.repos.d]# dd if=/dev/zero of=/demo5.log bs=1M count=40
記錄了40+0 的讀入
記錄了40+0 的寫出
41943040位元組(42 MB)已復制,0.737165 秒,56.9 MB/

將測驗檔案直接拷貝到掛載目錄下,查看兩個node服務器的存盤狀況

[root@client /]# cp demo* /test/dis/
[root@client /]# ls /test/dis/
demo1.log  demo2.log  demo3.log  demo4.log  demo5.log

在node服務器上查看

[root@node1 ~]# cd /data/sdb1
[root@node1 sdb1]# ll -h


總用量 160M
-rw-r--r--. 2 root root 40M 9  14 22:19 demo1.log
-rw-r--r--. 2 root root 40M 9  14 22:19 demo2.log
-rw-r--r--. 2 root root 40M 9  14 22:19 demo3.log
-rw-r--r--. 2 root root 40M 9  14 22:19 demo4.log
[root@node2 ~]# cd /data/sdb1
[root@node2 sdb1]# ll -h
總用量 40M
-rw-r--r--. 2 root root 40M 9  14 22:19 demo5.log

8、 條帶卷的創建與測驗

[root@node3 ~]# 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@node3 ~]# gluster volume list
dis-vol
stripe-vol
[root@node3 ~]# gluster volume start stripe-vol    ##開啟條帶卷
volume start: stripe-vol: success

在client服務器上掛載

[root@client /]# mkdir /test/stripe-vol
[root@client /]# mount.glusterfs node4:ss-vol /test/dis
sbin/ srv/  sys/  
[root@client /]# mount.glusterfs node4:stripe-vol /test/stripe-vol/
[root@client /]# df -hT
檔案系統         型別            容量  已用  可用 已用% 掛載點
/dev/sda5        xfs              40G  5.1G   35G   13% /
devtmpfs         devtmpfs        895M     0  895M    0% /dev
tmpfs            tmpfs           910M     0  910M    0% /dev/shm
tmpfs            tmpfs           910M   11M  900M    2% /run
tmpfs            tmpfs           910M     0  910M    0% /sys/fs/cgroup
/dev/sda2        xfs              50G   33M   50G    1% /home
/dev/sda1        xfs             2.0G  174M  1.9G    9% /boot
tmpfs            tmpfs           182M  8.0K  182M    1% /run/user/42
tmpfs            tmpfs           182M   40K  182M    1% /run/user/0
/dev/sr0         iso9660         4.3G  4.3G     0  100% /run/media/root/CentOS 7 x86_64
node4:dis-vol    fuse.glusterfs   40G  265M   40G    1% /test/dis
node4:stripe-vol fuse.glusterfs   40G   65M   40G    1% /test/stripe-vol
[root@client /]# cp demo* /test/stripe-vol/

在node服務器上進行查看

[root@node1 sdb1]# cd ../sdc1/
[root@node1 sdc1]# ll -h
總用量 100M
-rw-r--r--. 2 root root 20M 9  14 22:26 demo1.log
-rw-r--r--. 2 root root 20M 9  14 22:26 demo2.log
-rw-r--r--. 2 root root 20M 9  14 22:26 demo3.log
-rw-r--r--. 2 root root 20M 9  14 22:26 demo4.log
-rw-r--r--. 2 root root 20M 9  14 22:26 demo5.log
1
[root@node2 sdb1]# cd ../sdc1/
[root@node2 sdc1]# ll -h
總用量 100M
-rw-r--r--. 2 root root 20M 9  14 22:26 demo1.log
-rw-r--r--. 2 root root 20M 9  14 22:26 demo2.log
-rw-r--r--. 2 root root 20M 9  14 22:26 demo3.log
-rw-r--r--. 2 root root 20M 9  14 22:26 demo4.log
-rw-r--r--. 2 root root 20M 9  14 22:26 demo5.log

9、復制卷的創建與測驗

[root@node3 ~]# gluster volume create rep-vol replica 2 node3:/data/sdb1 node4:/data/sdb1 force
volume create: rep-vol: success: please start the volume to access data
[root@node3 ~]# gluster volume list
dis-vol
rep-vol
stripe-vol
[root@node3 ~]# gluster volume start rep-vol 
volume start: rep-vol: success

client服務器上

[root@client /]# mkdir /test/rep-vol
[root@client /]# mount.glusterfs node4:rep-vol /test/rep-vol/
[root@client /]# df -hT
檔案系統         型別            容量  已用  可用 已用% 掛載點
/dev/sda5        xfs              40G  5.1G   35G   13% /
devtmpfs         devtmpfs        895M     0  895M    0% /dev
tmpfs            tmpfs           910M     0  910M    0% /dev/shm
tmpfs            tmpfs           910M   11M  900M    2% /run
tmpfs            tmpfs           910M     0  910M    0% /sys/fs/cgroup
/dev/sda2        xfs              50G   33M   50G    1% /home
/dev/sda1        xfs             2.0G  174M  1.9G    9% /boot
tmpfs            tmpfs           182M  8.0K  182M    1% /run/user/42
tmpfs            tmpfs           182M   40K  182M    1% /run/user/0
/dev/sr0         iso9660         4.3G  4.3G     0  100% /run/media/root/CentOS 7 x86_64
node4:dis-vol    fuse.glusterfs   40G  265M   40G    1% /test/dis
node4:stripe-vol fuse.glusterfs   40G  265M   40G    1% /test/stripe-vol
node4:rep-vol    fuse.glusterfs   20G   33M   20G    1% /test/rep-vol
[root@client /]# cp demo* /test/rep-vol/

node服務器上查看

[root@node3 ~]# cd /data/sdb1/
[root@node3 sdb1]# ll -h
總用量 200M
-rw-r--r--. 2 root root 40M 9  14 22:31 demo1.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo2.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo3.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo4.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo5.log
[root@node4 ~]# cd /data/sdb1/
[root@node4 sdb1]# ll -h
總用量 200M
-rw-r--r--. 2 root root 40M 9  14 22:31 demo1.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo2.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo3.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo4.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo5.log

10、 分布式條帶卷的創建與測驗

[root@node3 sdb1]# gluster volume create dis-stripe stripe 2  node1:/data/sdd1 node2:/data/sdd1 node3:/data/sdd1 node4:/data/sdd1 force
volume create: dis-stripe: success: please start the volume to access data
[root@node3 sdb1]# gluster volume list
dis-stripe
dis-vol
rep-vol
stripe-vol
[root@node3 sdb1]# gluster volume start dis-stripe 
volume start: dis-stripe: success

client服務器

[root@client /]# mkdir /test/dis-stripe
[root@client /]# mount.glusterfs node4:dis-stripe /test/dis-stripe/
[root@client /]# df -Th
檔案系統         型別            容量  已用  可用 已用% 掛載點
/dev/sda5        xfs              40G  5.1G   35G   13% /
devtmpfs         devtmpfs        895M     0  895M    0% /dev
tmpfs            tmpfs           910M     0  910M    0% /dev/shm
tmpfs            tmpfs           910M   11M  900M    2% /run
tmpfs            tmpfs           910M     0  910M    0% /sys/fs/cgroup
/dev/sda2        xfs              50G   33M   50G    1% /home
/dev/sda1        xfs             2.0G  174M  1.9G    9% /boot
tmpfs            tmpfs           182M  8.0K  182M    1% /run/user/42
tmpfs            tmpfs           182M   40K  182M    1% /run/user/0
/dev/sr0         iso9660         4.3G  4.3G     0  100% /run/media/root/CentOS 7 x86_64
node4:dis-vol    fuse.glusterfs   40G  265M   40G    1% /test/dis
node4:stripe-vol fuse.glusterfs   40G  265M   40G    1% /test/stripe-vol
node4:rep-vol    fuse.glusterfs   20G  233M   20G    2% /test/rep-vol
node4:dis-stripe fuse.glusterfs   80G  130M   80G    1% /test/dis-stripe
[root@client /]# cp demo* /test/dis-stripe/

node服務器上查看

[root@node1 sdc1]# cd ../sdd1/
[root@node1 sdd1]# ll -h
總用量 80M
-rw-r--r--. 2 root root 20M 9  14 22:36 demo1.log
-rw-r--r--. 2 root root 20M 9  14 22:36 demo2.log
-rw-r--r--. 2 root root 20M 9  14 22:36 demo3.log
-rw-r--r--. 2 root root 20M 9  14 22:36 demo4.log
[root@node2 sdc1]# cd ../sdd1/
[root@node2 sdd1]# ll -h
總用量 80M
-rw-r--r--. 2 root root 20M 9  14 22:36 demo1.log
-rw-r--r--. 2 root root 20M 9  14 22:36 demo2.log
-rw-r--r--. 2 root root 20M 9  14 22:36 demo3.log
-rw-r--r--. 2 root root 20M 9  14 22:36 demo4.log

[root@node3 sdb1]# cd ../sdd1/
[root@node3 sdd1]# ll -h
總用量 20M
-rw-r--r--. 2 root root 20M 9  14 22:36 demo5.log
-rw-r--r--. 2 root root 40M 9  14 22:31 demo5.log
[root@node4 sdb1]# cd ../sdd1/
[root@node4 sdd1]# ll -h
總用量 20M
-rw-r--r--. 2 root root 20M 9  14 22:36 demo5.log

11、分布式復制卷

[root@node3 sdd1]# 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@node3 sdd1]# gluster volume list
dis-rep
dis-stripe
dis-vol
rep-vol
stripe-vol
[root@node3 sdd1]# gluster volume start dis-rep 

client服務器

[root@client /]# mkdir /test/dis-rep
[root@client /]# mount.glusterfs node4:dis-rep /test/dis-rep/
[root@client /]# df -Th
檔案系統         型別            容量  已用  可用 已用% 掛載點
/dev/sda5        xfs              40G  5.1G   35G   13% /
devtmpfs         devtmpfs        895M     0  895M    0% /dev
tmpfs            tmpfs           910M     0  910M    0% /dev/shm
tmpfs            tmpfs           910M   11M  900M    2% /run
tmpfs            tmpfs           910M     0  910M    0% /sys/fs/cgroup
/dev/sda2        xfs              50G   33M   50G    1% /home
/dev/sda1        xfs             2.0G  174M  1.9G    9% /boot
tmpfs            tmpfs           182M  8.0K  182M    1% /run/user/42
tmpfs            tmpfs           182M   40K  182M    1% /run/user/0
/dev/sr0         iso9660         4.3G  4.3G     0  100% /run/media/root/CentOS 7 x86_64
node4:dis-vol    fuse.glusterfs   40G  265M   40G    1% /test/dis
node4:stripe-vol fuse.glusterfs   40G  265M   40G    1% /test/stripe-vol
node4:rep-vol    fuse.glusterfs   20G  233M   20G    2% /test/rep-vol
node4:dis-stripe fuse.glusterfs   80G  330M   80G    1% /test/dis-stripe
node4:dis-rep    fuse.glusterfs   40G   65M   40G    1% /test/dis-rep
[root@client /]# cp demo* /test/dis-rep/

各個node服務器

[root@node1 sdd1]# cd ../sde1/
[root@node1 sde1]# ll -h
總用量 160M
-rw-r--r--. 2 root root 40M 9  14 22:40 demo1.log
-rw-r--r--. 2 root root 40M 9  14 22:40 demo2.log
-rw-r--r--. 2 root root 40M 9  14 22:40 demo3.log
-rw-r--r--. 2 root root 40M 9  14 22:40 demo4.log

[root@node2 sdd1]# cd ../sde1/
[root@node2 sde1]# ll -h
總用量 160M
-rw-r--r--. 2 root root 40M 9  14 22:40 demo1.log
-rw-r--r--. 2 root root 40M 9  14 22:40 demo2.log
-rw-r--r--. 2 root root 40M 9  14 22:40 demo3.log
-rw-r--r--. 2 root root 40M 9  14 22:40 demo4.log

[root@node3 sdd1]# cd ../sde1/
[root@node3 sde1]# ll -h
總用量 40M
-rw-r--r--. 2 root root 40M 9  14 22:40 demo5.log

[root@node4 sdd1]# cd ../sde1/
[root@node4 sde1]# ll -h
總用量 40M
-rw-r--r--. 2 root root 40M 9  14 22:40 demo5.log

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/59186.html

標籤:其他

上一篇:Linux基礎命令

下一篇:MySQL資料庫的編譯安裝程序

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more