Add new "backend_availability_zone" parameter to every volume backend. The parameters are optional, and when set they override the DEFAULT/storage_availability_zone for the corresponding backend. Implements: blueprint split-controlplane-cinder-volume-az Change-Id: I11821a38d8ba5afc594b3d601cd1634207a6f093
		
			
				
	
	
		
			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)
 | 
						|
 | 
						|
}
 |