Defined Type: cinder::backend::gpfs

Defined in:
manifests/backend/gpfs.pp

Overview

define: cinder::backend::gpfs

Configures Cinder to use the IBM GPFS Driver

Parameters

gpfs_mount_point_base

(required) Specifies the path of the GPFS directory where Block Storage volume and snapshot files are stored.

gpfs_images_dir

(optional) Specifies the path of the Image service repository in GPFS. Leave undefined if not storing images in GPFS. Defaults to “None” via driver. Defaults to <SERVICE DEFAULT>

gpfs_images_share_mode

(optional) Specifies the type of image copy to be used. Set this when the Image service repository also uses GPFS so that image files can be transferred efficiently from the Image service to the Block Storage service. There are two valid values: “copy” specifies that a full copy of the image is made; “copy_on_write” specifies that copy-on-write optimization strategy is used and unmodified blocks of the image file are shared efficiently. Defaults to “None” via driver. Defaults to <SERVICE DEFAULT>

gpfs_max_clone_depth

(optional) Specifies an upper limit on the number of indirections required to reach a specific block due to snapshots or clones. A lengthy chain of copy-on-write snapshots or clones can have a negative impact on performance, but improves space utilization. 0 indicates unlimited clone depth. Defaults to “0” via driver implementation Defaults to <SERVICE DEFAULT>

gpfs_sparse_volumes

(optional) Specifies that volumes are created as sparse files which initially consume no space. If set to False, the volume is created as a fully allocated file, in which case, creation may take a significantly longer time. Defaults to “True” via driver. Defaults to <SERVICE DEFAULT>

gpfs_storage_pool

(optional) Specifies the storage pool that volumes are assigned to. By default, the system storage pool is used. Defaults to “system” via driver. Defaults to <SERVICE DEFAULT>

nas_host

(optional) IP address or Hostname of the NAS system. Defaults to $::os_service_default

nas_login

(optional) User name to connect to NAS system. Defaults to $::os_service_default

nas_password

(optional) Password to connect to NAS system. Defaults to $::os_service_default

nas_private_key

(optional) Filename of private key to use for SSH authentication. Defaults to $::os_service_default

nas_ssh_port

(optional) SSH port to use to connect to NAS system. Defaults to $::os_service_default

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.

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 :

{ 'gpfs_backend/param1' => { 'value' => value1 } }

Authors

Benedikt von St. Vieth <b.von.st.vieth@fz-juelich.de>

Copyright 2015

Parameters:

  • gpfs_mount_point_base (Any)
  • gpfs_images_dir (Any) (defaults to: $::os_service_default)
  • gpfs_images_share_mode (Any) (defaults to: $::os_service_default)
  • gpfs_max_clone_depth (Any) (defaults to: $::os_service_default)
  • gpfs_sparse_volumes (Any) (defaults to: $::os_service_default)
  • gpfs_storage_pool (Any) (defaults to: $::os_service_default)
  • nas_host (Any) (defaults to: $::os_service_default)
  • nas_login (Any) (defaults to: $::os_service_default)
  • nas_password (Any) (defaults to: $::os_service_default)
  • nas_private_key (Any) (defaults to: $::os_service_default)
  • nas_ssh_port (Any) (defaults to: $::os_service_default)
  • backend_availability_zone (Any) (defaults to: $::os_service_default)
  • manage_volume_type (Any) (defaults to: false)
  • extra_options (Any) (defaults to: {})


93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
# File 'manifests/backend/gpfs.pp', line 93

define cinder::backend::gpfs (
  $gpfs_mount_point_base,
  $gpfs_images_dir           = $::os_service_default,
  $gpfs_images_share_mode    = $::os_service_default,
  $gpfs_max_clone_depth      = $::os_service_default,
  $gpfs_sparse_volumes       = $::os_service_default,
  $gpfs_storage_pool         = $::os_service_default,
  $nas_host                  = $::os_service_default,
  $nas_login                 = $::os_service_default,
  $nas_password              = $::os_service_default,
  $nas_private_key           = $::os_service_default,
  $nas_ssh_port              = $::os_service_default,
  $backend_availability_zone = $::os_service_default,
  $manage_volume_type        = false,
  $extra_options             = {},
) {

  include cinder::deps

  if ! ($gpfs_images_share_mode in ['copy', 'copy_on_write', $::os_service_default]) {
    fail('gpfs_images_share_mode only support `copy` or `copy_on_write`')
  }
  if $gpfs_images_share_mode in ['copy', 'copy_on_write'] and is_service_default($gpfs_images_dir) {
    fail('gpfs_images_share_mode only in conjunction with gpfs_images_dir')
  }

  cinder_config {
    "${name}/volume_driver":             value => 'cinder.volume.drivers.ibm.gpfs.GPFSDriver';
    "${name}/gpfs_max_clone_depth":      value => $gpfs_max_clone_depth;
    "${name}/gpfs_mount_point_base":     value => $gpfs_mount_point_base;
    "${name}/gpfs_sparse_volumes":       value => $gpfs_sparse_volumes;
    "${name}/gpfs_storage_pool":         value => $gpfs_storage_pool;
    "${name}/gpfs_images_share_mode":    value => $gpfs_images_share_mode;
    "${name}/gpfs_images_dir":           value => $gpfs_images_dir;
    "${name}/nas_host":                  value => $nas_host;
    "${name}/nas_login":                 value => $nas_login;
    "${name}/nas_password":              value => $nas_password, secret => true;
    "${name}/nas_private_key":           value => $nas_private_key;
    "${name}/nas_ssh_port":              value => $nas_ssh_port;
    "${name}/backend_availability_zone": value => $backend_availability_zone;
  }

  if $manage_volume_type {
    cinder_type { $name:
      ensure     => present,
      properties => ["volume_backend_name=${name}"],
    }
  }

  create_resources('cinder_config', $extra_options)

}