tripleo-heat-templates/deployment/cinder/cinder-backend-pure-puppet.yaml
Emilien Macchi 91e8ed328a Support deploying multiple Cinder Pure Storage backends
CinderPureBackendName is enhanced to support a list of backend names,
and a new CinderPureMultiConfig parameter provides a way to specify
parameter values for each backend. For example:

parameter_defaults:
  CinderEnableIscsiBackend: false
  CinderEnablePureBackend: true
  CinderPureBackendName:
    - tripleo_pure_1
    - tripleo_pure_2
  # These will be the default parameter values for each backend.
  CinderPureStorageProtocol: 'iSCSI'
  CinderPureUseChap: false
  CinderPureMultipathXfer: true
  CinderPureImageCache: true
  # Use CinderPureMultiConfig to override values in specific backends.
  CinderPureMultiConfig:
    tripleo_pure_1:
      CinderPureSanIp: '10.0.0.1'
      CinderPureAPIToken: 'secret'
    tripleo_pure_2:
      CinderPureSanIp: '10.0.0.2'
      CinderPureAPIToken: 'anothersecret'
      # This will take precedence over the default value.
      CinderPureUseChap: true

Co-Authored-By: Alan Bishop <abishop@redhat.com>
Depends-On: Ia7cc82f5eb4e228a43e47624d87e319ac5340268
Change-Id: I1083ef9893dede234b4cafd9888c898fa0e31077
2019-09-13 07:36:42 -07:00

104 lines
3.7 KiB
YAML

# Copyright (c) 2017 Pure Storage Inc, or its subsidiaries.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
heat_template_version: rocky
description: >
Openstack Cinder Pure Storage FlashArray backend
parameters:
ServiceData:
default: {}
description: Dictionary packing service data
type: json
ServiceNetMap:
default: {}
description: Mapping of service_name -> network name. Typically set
via parameter_defaults in the resource registry. This
mapping overrides those in ServiceNetMapDefaults.
type: json
DefaultPasswords:
default: {}
type: json
RoleName:
default: ''
description: Role name on which the service is applied
type: string
RoleParameters:
default: {}
description: Parameters specific to the role
type: json
EndpointMap:
default: {}
type: json
description: Mapping of service endpoint -> protocol. Typically set
via parameter_defaults in the resource registry.
CinderEnablePureBackend:
type: boolean
default: true
CinderPureBackendName:
type: comma_delimited_list
default: 'tripleo_pure'
description: A list of Cinder Pure Storage backend names.
CinderPureMultiConfig:
type: json
default: {}
description: >
Dictionary of settings when configuring multiple Pure backends. The
hash key is the backend name, and the value is a dictionary of parameter
values unique to that backend.
CinderPureAvailabilityZone:
default: ''
description: >
The availability zone of the Pure Storage Cinder backend.
When set, it overrides the default CinderStorageAvailabilityZone.
type: string
CinderPureStorageProtocol:
type: string
default: 'iSCSI'
CinderPureSanIp:
type: string
CinderPureAPIToken:
type: string
CinderPureUseChap:
type: boolean
default: false
CinderPureMultipathXfer:
type: boolean
default: true
CinderPureImageCache:
type: boolean
default: true
outputs:
role_data:
description: Role data for the Cinder Pure Storage FlashArray backend.
value:
service_name: cinder_backend_pure
config_settings:
map_merge:
- tripleo::profile::base::cinder::volume::cinder_enable_pure_backend: {get_param: CinderEnablePureBackend}
cinder::backend::pure::volume_backend_name: {get_param: CinderPureBackendName}
cinder::backend::pure::volume_multi_config: {get_param: CinderPureMultiConfig}
cinder::backend::pure::pure_storage_protocol: {get_param: CinderPureStorageProtocol}
cinder::backend::pure::san_ip: {get_param: CinderPureSanIp}
cinder::backend::pure::pure_api_token: {get_param: CinderPureAPIToken}
cinder::backend::pure::use_chap_auth: {get_param: CinderPureUseChap}
cinder::backend::pure::use_multipath_for_image_xfer: {get_param: CinderPureMultipathXfer}
cinder::backend::pure::image_volume_cache_enabled : {get_param: CinderPureImageCache}
-
if:
- {equals : [{get_param: CinderPureAvailabilityZone}, '']}
- {}
- cinder::backend::pure::backend_availability_zone: {get_param: CinderPureAvailabilityZone}