This cookbook is used to install and configure Gluster on both servers and clients. This cookbook makes several assumptions when configuring Gluster servers:
- This cookbook is being run on at least two nodes, the exact number depends on the Gluster Volume type
- A second physical disk has been added, unformatted, to the server. This cookbook will install lvm and configure the disks automatically.
- All peers for a volume will be configured with the same number of bricks
This cookbook has been tested on Ubuntu 12.04/14.04, CentOS 6.7 and CentOS 7.1
As this cookbook uses Semantic Versioning, major version number bumps are not backwards compatible. Especially the change from v4 to v5 will require a rebuild of the gluster nodes. This cookbook has been tested on Ubuntu 12.04/14.04, CentOS 6.5/7.1 and Debian Wheezy
node['gluster']['version']
- version to install, defaults to 3.4node['gluster']['repo']
- repo to install from: can be public or private, defaults to public, private requires a so-called "private" repo to be configured in a wrapper cookbook for example
Node attributes to specify volumes to mount. This has been deprecated in favor of using the 'gluster_mount' LWRP.
node['gluster']['client']['volumes'][VOLUME_NAME]['server']
- server to connect tonode['gluster']['client']['volumes'][VOLUME_NAME]['backup_server']
- name of the backup volfile server to mount the client. When the first volfile server fails, then the server specified here is used as volfile server and is mounted by the client. This can be a String or Array of Strings.node['gluster']['client']['volumes'][VOLUME_NAME]['mount_point']
- mount point to use for the Gluster volume
Node attributes to specify server volumes to create
The absolute minimum configuration is:
node['gluster']['server']['disks']
- an array of disks to create partitions on and format for use with Gluster, (for example, ['sdb', 'sdc'])node['gluster']['server']['volumes'][VOLUME_NAME]['peers']
- an array of FQDNs for peers used in the volumenode['gluster']['server']['volumes'][VOLUME_NAME]['volume_type']
- the volume type to use; this value can be 'replicated', 'distributed-replicated', 'distributed', 'striped' or 'distributed-striped'node['gluster']['server']['volumes'][VOLUME_NAME]['size']
- The size of the gluster volume you would like to create, for example, 100M or 5G. This is passed through to the lvm cookbook and uses the syntax defined here: https://github.com/chef-cookbooks/lvm .
Other attributes include:
node['gluster']['server']['brick_mount_path']
- default path to use for mounting bricksnode['gluster']['server']['disks']
- an array of disks to create partitions on and format for use with Gluster, (for example, ['sdb', 'sdc'])node['gluster']['server']['peer_retries']
- attempt to connect to peers up to N timesnode['gluster']['server']['peer_retry_delays']
- number of seconds to wait between attempts to initially attempt to connect to peersnode['gluster']['server']['volumes'][VOLUME_NAME]['allowed_hosts']
- an optional array of IP addresses to allow access to the volumenode['gluster']['server']['volumes'][VOLUME_NAME]['peer_names']
- an optional array of Chef node names for peers used in the volumenode['gluster']['server']['volumes'][VOLUME_NAME]['peers']
- an array of FQDNs for peers used in the volumenode['gluster']['server']['volumes'][VOLUME_NAME]['quota']
- an optional disk quota to set for the volume, such as '10GB'node['gluster']['server']['volumes'][VOLUME_NAME]['replica_count']
- the number of replicas to createnode['gluster']['server']['volumes'][VOLUME_NAME]['volume_type']
- the volume type to use; this value can be 'replicated', 'distributed-replicated', 'distributed', 'striped' or 'distributed-striped'node['gluster']['server']['volumes'][VOLUME_NAME]['size']
- The size of the gluster volume you would like to create, for example, 100M or 5G. This is passed through to the lvm cookbook.node['gluster']['server']['volumes'][VOLUME_NAME]['filesystem']
- The filesystem to use. This defaults to xfs.
Use the gluster_mount LWRP to mount volumes on clients:
gluster_mount 'volume_name' do
server 'gluster1.example.com'
backup_server 'gluster2.example.com'
mount_point '/mnt/gluster/volume_name'
action [:mount, :enable]
end
gluster_mount 'volume_name' do
server 'gluster1.example.com'
backup_server ['gluster2.example.com', 'gluster3.example.com']
mount_point '/mnt/gluster/volume_name'
action [:mount, :enable]
end
-
server
- The primary server to fetch the volfile from. Required. -
backup_server
- Backup servers to obtain the volfile from. Optional. -
mount_point
- The mount point on the local server to mount the glusterfs volume on. Created if non-existing. Required. -
mount_options
- Additional mount options added to the default options setdefaults,_netdev
. Optional. -
owner
- Owner of the underlying mount point directory. Defaults tonil
. Optional. -
group
- Group of the underlying mount point directory. Defaults tonil
. Optional. -
mode
- File mode of the underlying mount point directory. Defaults tonil
. Optional.
On two or more identical systems, attach the desired number of dedicated disks to use for Gluster storage. Add the gluster::server
recipe to the node's run list and add any appropriate attributes, such as volumes to the ['gluster']['server']['volumes']
attribute. If the cookbook will be used to manage disks, add the disks to the ['gluster']['server']['disks']
attribute; otherwise format the disks appropriately and add them to the ['gluster']['server']['volumes'][VOLUME_NAME]['disks']
attribute. Once all peers for a volume have configured their bricks, the 'master' peer (the first in the array) will create and start the volume.
For example, to create a replicated gluster volume named gv0 with 2 bricks on two nodes, add the following to your attributes/default.rb and include the gluster::server recipe:
default['gluster']['server']['brick_mount_path'] = "/data"
default['gluster']['server']['volumes'] = {
'gv0' => {
'peers' => ['gluster1.example.com','gluster2.example.com'],
'replica_count' => 2,
'volume_type' => "replicated"
}
}
To create a distributed-replicated volume with 4 bricks and a replica count of two:
default['gluster']['server']['brick_mount_path'] = "/data"
default['gluster']['server']['volumes'] = {
'gv0' => {
'peers' => ['gluster1.example.com','gluster2.example.com','gluster3.example.com','gluster4.example.com'],
'replica_count' => 2,
'volume_type' => "distributed-replicated"
}
}
To create a replicated volume with 4 bricks:
default['gluster']['server']['brick_mount_path'] = "/data"
default['gluster']['server']['volumes'] = {
'gv0' => {
'peers' => ['gluster1.example.com','gluster2.example.com','gluster3.example.com','gluster4.example.com'],
'replica_count' => 4,
'volume_type' => "replicated"
}
}
For clients, add the gluster::default or gluster::client recipe to the node's run list, and mount volumes using the gluster_mount
LWRP. The Gluster volume will be mounted on the next chef-client run (provided the volume exists and is available) and added to /etc/fstab.
There is a kitchen file provided to allow testing of the various versions. Examples of tests are:
(Depending on your shell, you may or may not need the \ in the RegEx)
To test a replicated volume on Ubuntu 12.04: kitchen converge replicated[12]-ubuntu-1204 kitchen verify replicated2-ubuntu-1204
To test a distributed-replicated volume on CentOS 7.1: kitchen converge distributed-repl[1234]-centos-71 kitchen verify distributed-repl4-centos-71
To test a striped volume on CentOS 6.5: kitchen converge striped[12]-centos-65 kitchen verify striped2-centos-65
Please note that at present the kitchen setup only supports Virtualbox