Debian 12 bookworm
Sponsored Link

GlusterFS : Dispersed 構成2023/06/19

 
GlusterFS によるストレージクラスターの設定です。
例として、6 ノードを使用した Dispersed 構成のボリュームを作成します。
Dispersed Volumes は イレイジャーコーディング [Erasure Coding (EC)] が基になっています。
Erasure Coding については他の有用な解説サイトを参照ください。
                                  |
+----------------------+          |          +----------------------+
| [GlusterFS Server#1] |10.0.0.51 | 10.0.0.54| [GlusterFS Server#4] |
|   node01.srv.world   +----------+----------+   node04.srv.world   |
|                      |          |          |                      |
+----------------------+          |          +----------------------+
                                  |
+----------------------+          |          +----------------------+
| [GlusterFS Server#2] |10.0.0.52 | 10.0.0.55| [GlusterFS Server#5] |
|   node02.srv.world   +----------+----------+   node05.srv.world   |
|                      |          |          |                      |
+----------------------+          |          +----------------------+
                                  |
+----------------------+          |          +----------------------+
| [GlusterFS Server#3] |10.0.0.53 | 10.0.0.56| [GlusterFS Server#6] |
|   node03.srv.world   +----------+----------+   node06.srv.world   |
|                      |                     |                      |
+----------------------+                     +----------------------+

 
前提として、クラスターを構成するノード群では GlusterFS に割り当てる領域は / パーティションとは別であることが推奨です。
( / 配下の任意のディレクトリでも設定は可能だが、非推奨のため、設定の際に強制オプションの付加が必要 )
[1]
[2] 全ノードで、ボリュームに割り当てるディレクトリを作成しておきます。
( 当例では、全ノードで [sdb1] を [/glusterfs] にマウント済み )
root@node01:~#
mkdir -p /glusterfs/dispersed

[3] いずれかのノードで以下のように設定します。
# 他のノードを探す

root@node01:~#
gluster peer probe node02

peer probe: success.
root@node01:~#
gluster peer probe node03

peer probe: success.
root@node01:~#
gluster peer probe node04

peer probe: success.
root@node01:~#
gluster peer probe node05

peer probe: success.
root@node01:~#
gluster peer probe node06

peer probe: success.
# 状態を表示

root@node01:~#
gluster peer status

Number of Peers: 5

Hostname: node02
Uuid: 312f36f7-47a4-48fa-91fc-1e3f8cd3d88f
State: Peer in Cluster (Connected)

Hostname: node03
Uuid: 299ee00a-9492-4dd3-afab-9df9d3c41960
State: Peer in Cluster (Connected)

Hostname: node04
Uuid: 77698649-65bc-4ea5-8072-12a01de51d18
State: Peer in Cluster (Connected)

Hostname: node05
Uuid: 4a4d1f71-70ee-47f5-8125-a66318675d37
State: Peer in Cluster (Connected)

Hostname: node06
Uuid: 2fe0bcbb-e721-4e0c-9fca-d782ada598c2
State: Peer in Cluster (Connected)

# ボリュームを作成

root@node01:~#
gluster volume create vol_dispersed disperse-data 4 redundancy 2 transport tcp \
node01:/glusterfs/dispersed \
node02:/glusterfs/dispersed \
node03:/glusterfs/dispersed \
node04:/glusterfs/dispersed \
node05:/glusterfs/dispersed \
node06:/glusterfs/dispersed

volume create: vol_dispersed: success: please start the volume to access data
# 作成したボリュームを起動

root@node01:~#
gluster volume start vol_dispersed

volume start: vol_dispersed: success
# ボリューム情報確認

root@node01:~#
gluster volume info


Volume Name: vol_dispersed
Type: Disperse
Volume ID: 26fef6fc-8cc0-4b02-8c03-31e284673758
Status: Started
Snapshot Count: 0
Number of Bricks: 1 x (4 + 2) = 6
Transport-type: tcp
Bricks:
Brick1: node01:/glusterfs/dispersed
Brick2: node02:/glusterfs/dispersed
Brick3: node03:/glusterfs/dispersed
Brick4: node04:/glusterfs/dispersed
Brick5: node05:/glusterfs/dispersed
Brick6: node06:/glusterfs/dispersed
Options Reconfigured:
storage.fips-mode-rchecksum: on
transport.address-family: inet
nfs.disable: on
[4]
GlusterFS ボリュームをマウントして利用するための クライアント側の設定はこちらを参照ください
関連コンテンツ