1e1be4fb56
Change-Id: Ib509c510e3e5ed19fbb1b5f68a060cde02d82eab
119 lines
3.8 KiB
Puppet
119 lines
3.8 KiB
Puppet
# == Class: cinder::backend::san
|
|
#
|
|
# Configures Cinder volume SAN driver.
|
|
# Parameters are particular to each volume driver.
|
|
#
|
|
# === Parameters
|
|
#
|
|
# [*volume_driver*]
|
|
# (required) Setup cinder-volume to use volume driver.
|
|
#
|
|
# [*volume_backend_name*]
|
|
# (optional) Allows for the volume_backend_name to be separate of $name.
|
|
# Defaults to: $name
|
|
#
|
|
# [*backend_availability_zone*]
|
|
# (Optional) Availability zone for this volume backend.
|
|
# If not set, the storage_availability_zone option value
|
|
# is used as the default for all backends.
|
|
# Defaults to $::os_service_default.
|
|
#
|
|
# [*san_thin_provision*]
|
|
# (optional) Use thin provisioning for SAN volumes? Defaults to true.
|
|
#
|
|
# [*san_ip*]
|
|
# (optional) IP address of SAN controller.
|
|
#
|
|
# [*san_login*]
|
|
# (optional) Username for SAN controller. Defaults to 'admin'.
|
|
#
|
|
# [*san_password*]
|
|
# (optional) Password for SAN controller.
|
|
#
|
|
# [*san_private_key*]
|
|
# (optional) Filename of private key to use for SSH authentication.
|
|
#
|
|
# [*san_clustername*]
|
|
# (optional) Cluster name to use for creating volumes.
|
|
#
|
|
# [*san_ssh_port*]
|
|
# (optional) SSH port to use with SAN. Defaults to 22.
|
|
#
|
|
# [*san_is_local*]
|
|
# (optional) Execute commands locally instead of over SSH
|
|
# use if the volume service is running on the SAN device.
|
|
#
|
|
# [*ssh_conn_timeout*]
|
|
# (optional) SSH connection timeout in seconds. Defaults to 30.
|
|
#
|
|
# [*ssh_min_pool_conn*]
|
|
# (optional) Minimum ssh connections in the pool.
|
|
#
|
|
# [*ssh_min_pool_conn*]
|
|
# (optional) Maximum ssh connections in the pool.
|
|
#
|
|
# [*ssh_max_pool_conn*]
|
|
# (Optional) Maximum ssh connections in the pool.
|
|
# Defaults to '5'.
|
|
#
|
|
# [*manage_volume_type*]
|
|
# (Optional) Whether or not manage Cinder Volume type.
|
|
# If set to true, a Cinder Volume type will be created
|
|
# with volume_backend_name=$volume_backend_name key/value.
|
|
# Defaults to false.
|
|
#
|
|
# [*extra_options*]
|
|
# (optional) Hash of extra options to pass to the backend stanza
|
|
# Defaults to: {}
|
|
# Example :
|
|
# { 'san_backend/param1' => { 'value' => value1 } }
|
|
#
|
|
define cinder::backend::san (
|
|
$volume_driver,
|
|
$volume_backend_name = $name,
|
|
$backend_availability_zone = $::os_service_default,
|
|
$san_thin_provision = true,
|
|
$san_ip = undef,
|
|
$san_login = 'admin',
|
|
$san_password = undef,
|
|
$san_private_key = undef,
|
|
$san_clustername = undef,
|
|
$san_ssh_port = 22,
|
|
$san_is_local = false,
|
|
$ssh_conn_timeout = 30,
|
|
$ssh_min_pool_conn = 1,
|
|
$ssh_max_pool_conn = 5,
|
|
$manage_volume_type = false,
|
|
$extra_options = {},
|
|
) {
|
|
|
|
include cinder::deps
|
|
|
|
cinder_config {
|
|
"${name}/volume_backend_name": value => $volume_backend_name;
|
|
"${name}/backend_availability_zone": value => $backend_availability_zone;
|
|
"${name}/volume_driver": value => $volume_driver;
|
|
"${name}/san_thin_provision": value => $san_thin_provision;
|
|
"${name}/san_ip": value => $san_ip;
|
|
"${name}/san_login": value => $san_login;
|
|
"${name}/san_password": value => $san_password, secret => true;
|
|
"${name}/san_private_key": value => $san_private_key;
|
|
"${name}/san_clustername": value => $san_clustername;
|
|
"${name}/san_ssh_port": value => $san_ssh_port;
|
|
"${name}/san_is_local": value => $san_is_local;
|
|
"${name}/ssh_conn_timeout": value => $ssh_conn_timeout;
|
|
"${name}/ssh_min_pool_conn": value => $ssh_min_pool_conn;
|
|
"${name}/ssh_max_pool_conn": value => $ssh_max_pool_conn;
|
|
}
|
|
|
|
if $manage_volume_type {
|
|
cinder_type { $volume_backend_name:
|
|
ensure => present,
|
|
properties => ["volume_backend_name=${volume_backend_name}"],
|
|
}
|
|
}
|
|
|
|
create_resources('cinder_config', $extra_options)
|
|
|
|
}
|