Debian 9 Stretch
Sponsored Link

GlusterFS : 分散 + レプリカ構成2017/06/21

 
GlusterFS によるストレージクラスターの設定です。
例として、4台のサーバー中の 2台のサーバー間でそれぞれレプリカ構成をとりつつ、レプリカ構成を設定した 2台のサーバーを 1組とした 2組間でファイル単位で分散保管する 分散 + レプリカ構成を設定します。
                                  |
+----------------------+          |          +----------------------+
| [GlusterFS Server#1] |10.0.0.51 | 10.0.0.52| [GlusterFS Server#2] |
|   node01.srv.world   +----------+----------+   node02.srv.world   |
|                      |          |          |                      |
+----------------------+          |          +----------------------+
                                  |
+----------------------+          |          +----------------------+
| [GlusterFS Server#3] |10.0.0.53 | 10.0.0.54| [GlusterFS Server#4] |
|   node03.srv.world   +----------+----------+   node04.srv.world   |
|                      |                     |                      |
+----------------------+                     +----------------------+

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

[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 status

Number of Peers: 3

Hostname: node02
Uuid: a39156f3-32cb-451e-9e34-08ce504d72bb
State: Peer in Cluster (Connected)

Hostname: node03
Uuid: b86b98e4-12b6-4581-984d-da420d7b3bbe
State: Peer in Cluster (Connected)

Hostname: node04
Uuid: 6a1fb91a-f483-48c7-8dc7-0f2ac4d8db94
State: Peer in Cluster (Connected)

# ボリュームを作成

root@node01:~#
gluster volume create vol_dist-replica replica 2 transport tcp \
node01:/var/lib/glusterfs/dist-replica \
node02:/var/lib/glusterfs/dist-replica \
node03:/var/lib/glusterfs/dist-replica \
node04:/var/lib/glusterfs/dist-replica

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

root@node01:~#
gluster volume start vol_dist-replica

volume start: vol_dist-replica: success
# ボリューム情報確認

root@node01:~#
gluster volume info


Volume Name: vol_dist-replica
Type: Distributed-Replicate
Volume ID: 539f9993-90c6-4b7a-88ab-43a860dfe165
Status: Started
Snapshot Count: 0
Number of Bricks: 2 x 2 = 4
Transport-type: tcp
Bricks:
Brick1: node01:/var/lib/glusterfs/dist-replica
Brick2: node02:/var/lib/glusterfs/dist-replica
Brick3: node03:/var/lib/glusterfs/dist-replica
Brick4: node04:/var/lib/glusterfs/dist-replica
Options Reconfigured:
transport.address-family: inet
performance.readdir-ahead: on
nfs.disable: on
[4] クライアントから NFS マウントを利用する場合は、事前に必要なサービスの起動と、以下の設定の変更が必要です。
root@node01:~#
gluster volume set vol_dist-replica nfs.disable off

volume set: success
[5]
GlusterFS ボリュームをマウントして利用するための クライアント側の設定はこちらを参照ください
関連コンテンツ