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