File: solidfire.pp

package info (click to toggle)
puppet-module-cinder 27.0.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 2,512 kB
  • sloc: ruby: 6,697; python: 33; sh: 10; makefile: 10
file content (188 lines) | stat: -rw-r--r-- 7,882 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
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
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
# == Class: cinder::backend::solidfire
#
# Configures Cinder volume SolidFire driver.
# Parameters are particular to each volume driver.
#
# === Parameters
#
# [*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 $facts['os_service_default'].
#
# [*image_volume_cache_enabled*]
#   (Optional) Enable Cinder's image cache function for this backend.
#   Defaults to $facts['os_service_default'],
#
# [*image_volume_cache_max_size_gb*]
#   (Optional) Max size of the image volume cache for this backend in GB.
#   Defaults to $facts['os_service_default'],
#
# [*image_volume_cache_max_count*]
#   (Optional) Max number of entries allowed in the image volume cache.
#   Defaults to $facts['os_service_default'],
#
# [*reserved_percentage*]
#   (Optional) The percentage of backend capacity is reserved.
#   Defaults to $facts['os_service_default'].
#
# [*max_over_subscription_ratio*]
#   (Optional) Representation of the over subscription ratio when thin
#   provisionig is involved.
#   Defaults to $facts['os_service_default'].
#
# [*volume_driver*]
#   (optional) Setup cinder-volume to use SolidFire volume driver.
#   Defaults to 'cinder.volume.drivers.solidfire.SolidFireDriver'
#
# [*san_ip*]
#   (required) IP address of SolidFire clusters MVIP.
#
# [*san_login*]
#   (required) Username for SolidFire admin account.
#
# [*san_password*]
#   (required) Password for SolidFire admin account.
#
# [*sf_emulate_512*]
#   (optional) Use 512 byte emulation for volumes.
#   Defaults to $facts['os_service_default']
#
# [*sf_allow_tenant_qos*]
#   (optional) Allow tenants to specify QoS via volume metadata.
#   Defaults to $facts['os_service_default']
#
# [*sf_account_prefix*]
#   (optional) Prefix to use when creating tenant accounts on SolidFire Cluster.
#   Defaults to $facts['os_service_default']
#
# [*sf_api_port*]
#   (optional) Port ID to use to connect to SolidFire API.
#   Defaults to $facts['os_service_default']
#
# [*sf_volume_prefix*]
#   (optional) Create SolidFire volumes with this prefix. Volume names
#   are of the form <sf_volume_prefix><cinder-volume-id>.
#   Defaults to $facts['os_service_default']-
#
# [*sf_svip*]
#   (optional) Overrides default cluster SVIP with the one specified.
#   This is required or deployments that have implemented the use of
#   VLANs for iSCSI networks in their cloud.
#   Defaults to $facts['os_service_default']
#
# [*sf_enable_vag*]
#   (optional) Utilize volume access groups on a per-tenant basis.
#   Defaults to $facts['os_service_default']
#
# [*sf_provisioning_calc*]
#   (optional) Change how SolidFire reports used space and provisioning
#   calculations.
#   Defaults to $facts['os_service_default']
#
# [*sf_cluster_pairing_timeout*]
#   (optional) Sets time in seconds to wait for cluster to complete paring.
#   Defaults to $facts['os_service_default']
#
# [*sf_volume_pairing_timeout*]
#   (optional) Sets time in seconds to wait for a migrating volume to complete
#   paring and sync.
#   Defaults to $facts['os_service_default']
#
# [*sf_api_request_timeout*]
#   (optional) Sets time in seconds to wait for an api request to complete.
#   Defaults to $facts['os_service_default']
#
# [*sf_volume_clone_timeout*]
#   (optional) Sets time in seconds to wait for a clone of a volume or snapshot
#   to complete.
#   Defaults to $facts['os_service_default']
#
# [*sf_volume_create_timeout*]
#   (optional) Sets time in seconds to wait for a create volume operation to
#   complete.
#   Defaults to $facts['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 :
#     { 'solidfire_backend/param1' => { 'value' => value1 } }
#
define cinder::backend::solidfire (
  $san_ip,
  $san_login,
  $san_password,
  $volume_backend_name            = $name,
  $backend_availability_zone      = $facts['os_service_default'],
  $image_volume_cache_enabled     = $facts['os_service_default'],
  $image_volume_cache_max_size_gb = $facts['os_service_default'],
  $image_volume_cache_max_count   = $facts['os_service_default'],
  $reserved_percentage            = $facts['os_service_default'],
  $max_over_subscription_ratio    = $facts['os_service_default'],
  $volume_driver                  = 'cinder.volume.drivers.solidfire.SolidFireDriver',
  $sf_emulate_512                 = $facts['os_service_default'],
  $sf_allow_tenant_qos            = $facts['os_service_default'],
  $sf_account_prefix              = $facts['os_service_default'],
  $sf_api_port                    = $facts['os_service_default'],
  $sf_volume_prefix               = $facts['os_service_default'],
  $sf_svip                        = $facts['os_service_default'],
  $sf_enable_vag                  = $facts['os_service_default'],
  $sf_provisioning_calc           = $facts['os_service_default'],
  $sf_cluster_pairing_timeout     = $facts['os_service_default'],
  $sf_volume_pairing_timeout      = $facts['os_service_default'],
  $sf_api_request_timeout         = $facts['os_service_default'],
  $sf_volume_clone_timeout        = $facts['os_service_default'],
  $sf_volume_create_timeout       = $facts['os_service_default'],
  Boolean $manage_volume_type     = false,
  Hash $extra_options             = {},
) {
  include cinder::deps

  cinder_config {
    "${name}/volume_backend_name":            value => $volume_backend_name;
    "${name}/backend_availability_zone":      value => $backend_availability_zone;
    "${name}/image_volume_cache_enabled":     value => $image_volume_cache_enabled;
    "${name}/image_volume_cache_max_size_gb": value => $image_volume_cache_max_size_gb;
    "${name}/image_volume_cache_max_count":   value => $image_volume_cache_max_count;
    "${name}/reserved_percentage":            value => $reserved_percentage;
    "${name}/max_over_subscription_ratio":    value => $max_over_subscription_ratio;
    "${name}/volume_driver":                  value => $volume_driver;
    "${name}/san_ip":                         value => $san_ip;
    "${name}/san_login":                      value => $san_login;
    "${name}/san_password":                   value => $san_password, secret => true;
    "${name}/sf_emulate_512":                 value => $sf_emulate_512;
    "${name}/sf_allow_tenant_qos":            value => $sf_allow_tenant_qos;
    "${name}/sf_account_prefix":              value => $sf_account_prefix;
    "${name}/sf_api_port":                    value => $sf_api_port;
    "${name}/sf_volume_prefix":               value => $sf_volume_prefix;
    "${name}/sf_svip":                        value => $sf_svip;
    "${name}/sf_enable_vag":                  value => $sf_enable_vag;
    "${name}/sf_provisioning_calc":           value => $sf_provisioning_calc;
    "${name}/sf_cluster_pairing_timeout":     value => $sf_cluster_pairing_timeout;
    "${name}/sf_volume_pairing_timeout":      value => $sf_volume_pairing_timeout;
    "${name}/sf_api_request_timeout":         value => $sf_api_request_timeout;
    "${name}/sf_volume_clone_timeout":        value => $sf_volume_clone_timeout;
    "${name}/sf_volume_create_timeout":       value => $sf_volume_create_timeout;
  }

  if $manage_volume_type {
    cinder_type { $volume_backend_name:
      ensure     => present,
      properties => { 'volume_backend_name' => $volume_backend_name },
    }
  }

  create_resources('cinder_config', $extra_options)
}