GlusterFS Setup¶
Requirements¶
GlusterFS is only supported on 64bit systems, so make sure the host machine running GlusterFS and any machines utilising the share is also running on a 64bit system.
This guide is created for Ubuntu 22.04 jammy
Steps to follow¶
Run the following commands on all systems that will be utilising the share, as well as the host system.
Adding Hosts to /etc/hosts¶
We want to make sure our machines can talk to each other via their host names, this can be done by editing and adding the following.
Edit /etc/hosts
Add in your IP addresses and Hostnames of your machines that will be using GlusterFS, this is my example on my GlusterFS host machine, but remember to add this to all your nodes that will be using GlusterFS
127.0.0.1 localhost
127.0.1.1 elzim
192.168.68.109 elzim
192.168.68.105 pi4lab01
192.168.68.114 pi4lab02
Installing GlusterFS¶
Setup the GlusterFS repository. At the time of writing this, GlusterFS-10 is the latest release.
Run an apt update to update the repositories.
Install GlusterFS
Start and enable GlusterFS
Peering the Nodes¶
This command is only run on the host machine
Before running the peering command, make sure you run it under sudo via
The following command will peer all the nodes to the GlusterFS Pool, this is using the hostnames for my environment, make sure to change this to suit yours.
Running the below command will show your hosts now connected to the pool.
Creating the Gluster Volume¶
Let's create the directory that will be used for the GlusterFS volume - This is run on all nodes
Note: You can name "volumes" to anything you like.
Now we can create the volume across the Gluster pool - This is run just on the host
sudo gluster volume create staging-gfs replica 3 elzim:/gluster/volumes pi4lab01:/gluster/volumes pi4lab02:/gluster/volumes force
Start the volume by running the below command
To ensure the volume automatically mounts on reboot or other circumstances, follow these steps on all machines:
-
- Switch to the root user by running:
sudo -s
. - Append the following line to the
/etc/fstab
file using the command:echo 'localhost:/staging-gfs /mnt glusterfs defaults,_netdev,backupvolfile-server=localhost 0 0' >> /etc/fstab
. - Mount the GlusterFS volume to the
/mnt
directory with the command:mount.glusterfs localhost:/staging-gfs /mnt
. - Set the ownership of the
/mnt
directory and its contents toroot:docker
using:chown -R root:docker /mnt
. - Exit the root user session by running:
exit
.
- Switch to the root user by running:
To verify that the GlusterFS volume is successfully mounted, run the command: df -h
.
Files created in the /mnt directory will now show up in the**/gluster/volumes** directorie on every machine.
Youtube Video¶
If there is an issue with this guide or you wish to suggest changes, please raise an issue on GitHub.