This is a summary of some useful GPFS concepts and commands. Before doing any administrative work on a GPFS system you should consult the official docs.
Some commands can be run as root from any node in the GPFS cluster including clients. Depending on how the cluster is configured some commands can only be run from a limited number of administrative nodes.
Install the GPFS packages on the new node, for example using the gpfs
Ansible role in this repository.
You can then manually add the node to the GPFS cluster using these instructions as a guide.
First log into a root shell on one of the GPFS admin nodes. Commands will be sent from the admin nodes to the other cluster nodes, this is why password-less ssh root access is required.
- Check you can ssh as root without a password into the new node
- Check the reverse IP of the new node matches it's hostname
- Run
mmaddnode -N new.node.hostname
to add the node - Run
mmchlicense {client|server} --accept -N new.node.hostname
to assign a license - Run
mmlscluster
andmmlslicense
to check the cluster - Run
mmstartup -N new.node.hostname
to start GPFS on the new node - Wait a few minutes for the node to initialise. GPFS may be mounted automatically in which case you do not need to do anything, otherwise run
mmmount filesystem-name -N new.node.hostname
to enable the mount on the new node (this will automatically add an entry to/etc/fstab
) - You can check the state of all nodes by running
mmgetstate -a
Note do not edit /etc/fstab
directly (it is managed centrally by GPFS).
A GPFS fileset is a subtree of a GPFS file-system that can be managed separately.
For example, policies can be set so that data is only stored on a subset of disks for performance, and (read-only) snapshots can be created of the subtree.
If you want to use snaphots you must create the fileset with the --inode-space new
parameter, and you may want to specify the maximum number of inodes using ‐‐inode‐limit MaxNumInodes
.
A larger number of inodes requires more metadata space, so it should not be too large.
For example, if you have a GPFS filesystem called gpfs-1
mounted on /data
and you want to create a new fileset called downloads
with an initial maximum of 100k inodes:
mmcrfileset gpfs-1 downloads --inode-space new ‐‐inode‐limit 100k
mmlinkfileset gpfs-1 downloads -J /data/downloads
You can increase the maximum number of inodes after creating the fileset:
mmchfileset gpfs-1 downloads ‐‐inode‐limit 1m
Note it is not possible to convert an existing directory into a fileset.
To list existing filesets:
mmlsfileset gpfs-1
Add -L
to see additional information include any inode limits.
To delete a fileset:
mmunlinkfileset gpfs-1 downloads
mmdelfileset gpfs-1 downloads
If the fileset was not empty pass -f
to mmdelfileset
.
GPFS snapshots are read-only snapshots of either the entire GPFS filesystem, or a single fileset. They are useful for taking consistent backups of an subtree, or for tagging versions of a directory for future reference. GPFS uses a form of copy-on-write so is not the same as a backup.
- http://www.ibm.com/support/knowledgecenter/STXKQY_4.1.1/com.ibm.spectrum.scale.v4r11.adv.doc/bl1adv_logcopy.htm
- http://www.ibm.com/support/knowledgecenter/STXKQY_4.1.1/com.ibm.spectrum.scale.v4r11.adv.doc/bl1adv_fslevelsnaps.htm%23bl1adv_fslevelsnaps
To create a snapshot of the downloads
fileset called downloads-0.1
:
mmcrsnapshot gpfs-1 downloads-0.1 -j downloads
To list all snapshots:
mmlssnapshot gpfs-1
To delete a snapshot:
mmdelsnapshot gpfs-1 downloads-0.1 -j downloads
Any directory can be made into a share, but to avoid problems ensure there are no nested shares. For example, to add a read-write share accessible to 10.0.0.0/8 with the default root-squash and support for NFS3 and NFS4:
mmnfs export add /data/downloads -c "10.0.0.0/8(Access_Type=RW,Protocols=3:4)"
To add client settings to an existing share:
mmnfs export change /data/downloads --nfsadd "192.168.1.0/24(Access_Type=RO,Protocols=3:4)"
Use --nfschange
to change existing client settings.
See the documentation for the full set of client options.