Add configuration helpers for Quobyte
The Quobyte system is conceptionally similar to GlusterFS, which is why their Cinder driver is forked from the GlusterFS Cinder driver, so I have taken the same approach here. Change-Id: I5f207a2ca18bc039ad9d4a6036cec4ad84d5d5f5
This commit is contained in:
63
manifests/backend/quobyte.pp
Normal file
63
manifests/backend/quobyte.pp
Normal file
@@ -0,0 +1,63 @@
|
||||
#
|
||||
# == Class: cinder::backend::quobyte
|
||||
#
|
||||
# Configures Cinder to use Quobyte USP as a volume driver
|
||||
#
|
||||
# === Parameters
|
||||
#
|
||||
# [*quobyte_volume_url*]
|
||||
# (required) The URL of the Quobyte volume to use.
|
||||
# Not an array as a Quobyte driver instance supports exactly one volume
|
||||
# at a time - but you can load the driver more than once.
|
||||
# Example: quobyte://quobyte.cluster.example.com/volume-name
|
||||
#
|
||||
# [*quobyte_client_cfg*]
|
||||
# (optional) Path to a Quobyte client configuration file.
|
||||
# This is needed if client certificate authentication is enabled on the
|
||||
# Quobyte cluster. The config file includes the certificate and key.
|
||||
#
|
||||
# [*quobyte_qcow2_volumes*]
|
||||
# (optional) Boolean if volumes should be created as qcow2 volumes.
|
||||
# Defaults to True. qcow2 volumes allow snapshots, at the cost of a small
|
||||
# performance penalty. If False, raw volumes will be used.
|
||||
#
|
||||
# [*quobyte_sparsed_volumes*]
|
||||
# (optional) Boolean if raw volumes should be created as sparse files.
|
||||
# Defaults to True. Non-sparse volumes may have a very small performance
|
||||
# benefit, but take a long time to create.
|
||||
#
|
||||
# [*quobyte_mount_point_base*]
|
||||
# (optional) Path where the driver should create mountpoints.
|
||||
# Defaults to a subdirectory "mnt" under the Cinder state directory.
|
||||
#
|
||||
# [*volume_backend_name*]
|
||||
# (optional) Allows for the volume_backend_name to be separate of $name.
|
||||
# Defaults to: $name
|
||||
#
|
||||
# === Examples
|
||||
#
|
||||
# cinder::backend::quobyte { 'quobyte1':
|
||||
# quobyte_volume_url => 'quobyte://quobyte.cluster.example.com/volume-name',
|
||||
# }
|
||||
#
|
||||
define cinder::backend::quobyte (
|
||||
$quobyte_volume_url,
|
||||
$quobyte_client_cfg = undef,
|
||||
$quobyte_qcow2_volumes = undef,
|
||||
$quobyte_sparsed_volumes = undef,
|
||||
$quobyte_mount_point_base = undef,
|
||||
$volume_backend_name = $name,
|
||||
) {
|
||||
|
||||
cinder_config {
|
||||
"${name}/volume_backend_name": value => $volume_backend_name;
|
||||
"${name}/volume_driver": value =>
|
||||
'cinder.volume.drivers.quobyte.QuobyteDriver';
|
||||
"${name}/quobyte_volume_url": value => $quobyte_volume_url;
|
||||
"${name}/quobyte_client_cfg": value => $quobyte_client_cfg;
|
||||
"${name}/quobyte_qcow2_volumes": value => $quobyte_qcow2_volumes;
|
||||
"${name}/quobyte_sparsed_volumes": value => $quobyte_sparsed_volumes;
|
||||
"${name}/quobyte_mount_point_base": value => $quobyte_mount_point_base;
|
||||
}
|
||||
|
||||
}
|
||||
55
manifests/volume/quobyte.pp
Normal file
55
manifests/volume/quobyte.pp
Normal file
@@ -0,0 +1,55 @@
|
||||
#
|
||||
# == Class: cinder::volume::quobyte
|
||||
#
|
||||
# Configures Cinder to use Quobyte USP as a volume driver
|
||||
#
|
||||
# === Parameters
|
||||
#
|
||||
# [*quobyte_volume_url*]
|
||||
# (required) The URL of the Quobyte volume to use.
|
||||
# Not an array as a Quobyte driver instance supports exactly one volume
|
||||
# at a time - but you can load the driver more than once.
|
||||
# Example: quobyte://quobyte.cluster.example.com/volume-name
|
||||
#
|
||||
# [*quobyte_client_cfg*]
|
||||
# (optional) Path to a Quobyte client configuration file.
|
||||
# This is needed if client certificate authentication is enabled on the
|
||||
# Quobyte cluster. The config file includes the certificate and key.
|
||||
#
|
||||
# [*quobyte_qcow2_volumes*]
|
||||
# (optional) Boolean if volumes should be created as qcow2 volumes.
|
||||
# Defaults to True. qcow2 volumes allow snapshots, at the cost of a small
|
||||
# performance penalty. If False, raw volumes will be used.
|
||||
#
|
||||
# [*quobyte_sparsed_volumes*]
|
||||
# (optional) Boolean if raw volumes should be created as sparse files.
|
||||
# Defaults to True. Non-sparse volumes may have a very small performance
|
||||
# benefit, but take a long time to create.
|
||||
#
|
||||
# [*quobyte_mount_point_base*]
|
||||
# (optional) Path where the driver should create mountpoints.
|
||||
# Defaults to a subdirectory "mnt" under the Cinder state directory.
|
||||
#
|
||||
# === Examples
|
||||
#
|
||||
# class { 'cinder::volume::quobyte':
|
||||
# quobyte_volume_url => 'quobyte://quobyte.cluster.example.com/volume-name',
|
||||
# }
|
||||
#
|
||||
class cinder::volume::quobyte (
|
||||
$quobyte_volume_url,
|
||||
$quobyte_client_cfg = undef,
|
||||
$quobyte_qcow2_volumes = undef,
|
||||
$quobyte_sparsed_volumes = undef,
|
||||
$quobyte_mount_point_base = undef,
|
||||
) {
|
||||
|
||||
cinder::backend::quobyte { 'DEFAULT':
|
||||
quobyte_volume_url => $quobyte_volume_url,
|
||||
quobyte_client_cfg => $quobyte_client_cfg,
|
||||
quobyte_qcow2_volumes => $quobyte_qcow2_volumes,
|
||||
quobyte_sparsed_volumes => $quobyte_sparsed_volumes,
|
||||
quobyte_mount_point_base => $quobyte_mount_point_base,
|
||||
}
|
||||
|
||||
}
|
||||
43
spec/classes/cinder_volume_quobyte_spec.rb
Normal file
43
spec/classes/cinder_volume_quobyte_spec.rb
Normal file
@@ -0,0 +1,43 @@
|
||||
require 'spec_helper'
|
||||
|
||||
describe 'cinder::volume::quobyte' do
|
||||
|
||||
shared_examples_for 'quobyte volume driver' do
|
||||
let :params do
|
||||
{
|
||||
:quobyte_volume_url => 'quobyte://quobyte.cluster.example.com/volume-name',
|
||||
:quobyte_qcow2_volumes => false,
|
||||
:quobyte_sparsed_volumes => true,
|
||||
}
|
||||
end
|
||||
|
||||
it 'configures quobyte volume driver' do
|
||||
should contain_cinder_config('DEFAULT/volume_driver').with_value(
|
||||
'cinder.volume.drivers.quobyte.QuobyteDriver')
|
||||
should contain_cinder_config('DEFAULT/quobyte_volume_url').with_value(
|
||||
'quobyte://quobyte.cluster.example.com/volume-name')
|
||||
should contain_cinder_config('DEFAULT/quobyte_qcow2_volumes').with_value(
|
||||
false)
|
||||
should contain_cinder_config('DEFAULT/quobyte_sparsed_volumes').with_value(
|
||||
true)
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
context 'on Debian platforms' do
|
||||
let :facts do
|
||||
{ :osfamily => 'Debian' }
|
||||
end
|
||||
|
||||
it_configures 'quobyte volume driver'
|
||||
end
|
||||
|
||||
context 'on RedHat platforms' do
|
||||
let :facts do
|
||||
{ :osfamily => 'RedHat' }
|
||||
end
|
||||
|
||||
it_configures 'quobyte volume driver'
|
||||
end
|
||||
|
||||
end
|
||||
45
spec/defines/cinder_backend_quobyte_spec.rb
Normal file
45
spec/defines/cinder_backend_quobyte_spec.rb
Normal file
@@ -0,0 +1,45 @@
|
||||
require 'spec_helper'
|
||||
|
||||
describe 'cinder::backend::quobyte' do
|
||||
|
||||
shared_examples_for 'quobyte volume driver' do
|
||||
let(:title) {'myquobyte'}
|
||||
|
||||
let :params do
|
||||
{
|
||||
:quobyte_volume_url => 'quobyte://quobyte.cluster.example.com/volume-name',
|
||||
:quobyte_qcow2_volumes => false,
|
||||
:quobyte_sparsed_volumes => true,
|
||||
}
|
||||
end
|
||||
|
||||
it 'configures quobyte volume driver' do
|
||||
should contain_cinder_config('myquobyte/volume_driver').with_value(
|
||||
'cinder.volume.drivers.quobyte.QuobyteDriver')
|
||||
should contain_cinder_config('myquobyte/quobyte_volume_url').with_value(
|
||||
'quobyte://quobyte.cluster.example.com/volume-name')
|
||||
should contain_cinder_config('myquobyte/quobyte_qcow2_volumes').with_value(
|
||||
false)
|
||||
should contain_cinder_config('myquobyte/quobyte_sparsed_volumes').with_value(
|
||||
true)
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
context 'on Debian platforms' do
|
||||
let :facts do
|
||||
{ :osfamily => 'Debian' }
|
||||
end
|
||||
|
||||
it_configures 'quobyte volume driver'
|
||||
end
|
||||
|
||||
context 'on RedHat platforms' do
|
||||
let :facts do
|
||||
{ :osfamily => 'RedHat' }
|
||||
end
|
||||
|
||||
it_configures 'quobyte volume driver'
|
||||
end
|
||||
|
||||
end
|
||||
Reference in New Issue
Block a user