
- Add EMC attributes - Create cinder_emc_config.xml when EMC driver is used. - Installs appropriate packages when EMC driver is used. - Add tests for new cinder_emc_config.xml - Add tests for changed attributes in existing cinder.conf - Add tests for package installs Change-Id: I5a44e3626784814f57e15a43ce459a4d36d31c6b Implements: blueprint emc-cinder-provider
Description
Installs the OpenStack Block Storage service Cinder as part of the OpenStack reference deployment Chef for OpenStack. The https://github.com/stackforge/openstack-chef-repo contains documentation for using this cookbook in the context of a full OpenStack deployment. Cinder is currently installed from packages.
Requirements
- Chef 0.10.0 or higher required (for Chef environment use).
Cookbooks
The following cookbooks are dependencies:
- apt
- openstack-common
- openstack-identity
- openstack-image
- selinux (Fedora)
Usage
api
- Installs the cinder-api, sets up the cinder database, and cinder service/user/endpoints in keystone
client
- Install the cinder client packages
scheduler
- Installs the cinder-scheduler service
volume
- Installs the cinder-volume service, sets up the iscsi helper and create volume group when using the LVMISCSIDriver
Defaults to the ISCSI (LVM) Driver.
Attributes
openstack["block-storage"]["db"]["username"]
- cinder username for database TODO: Add DB2 support on other platformsopenstack["block-storage"]["platform"]["db2_python_packages"]
- Array of DB2 python packages, only available on redhat platformopenstack["block-storage"]["volume_name_template"]
- Template string to be used to generate volume namesopenstack["block-storage"]["snapshot_name_template"]
- Template string to be used to generate snapshot names
MQ attributes
-
openstack["block-storage"]["mq"]["service_type"]
- Select qpid or rabbitmq. default rabbitmq TODO: move rabbit parameters under openstack["block-storage"]["mq"] -
openstack["block-storage"]["rabbit"]["username"]
- Username for nova rabbit access -
openstack["block-storage"]["rabbit"]["vhost"]
- The rabbit vhost to use -
openstack["block-storage"]["rabbit"]["port"]
- The rabbit port to use -
openstack["block-storage"]["rabbit"]["host"]
- The rabbit host to use (must set whenopenstack["block-storage"]["rabbit"]["ha"]
false). -
openstack["block-storage"]["rabbit"]["ha"]
- Whether or not to use rabbit ha -
openstack["block-storage"]["mq"]["qpid"]["host"]
- The qpid host to use -
openstack["block-storage"]["mq"]["qpid"]["port"]
- The qpid port to use -
openstack["block-storage"]["mq"]["qpid"]["qpid_hosts"]
- Qpid hosts. TODO. use only when ha is specified. -
openstack["block-storage"]["mq"]["qpid"]["username"]
- Username for qpid connection -
openstack["block-storage"]["mq"]["qpid"]["password"]
- Password for qpid connection -
openstack["block-storage"]["mq"]["qpid"]["sasl_mechanisms"]
- Space separated list of SASL mechanisms to use for auth -
openstack["block-storage"]["mq"]["qpid"]["reconnect_timeout"]
- The number of seconds to wait before deciding that a reconnect attempt has failed. -
openstack["block-storage"]["mq"]["qpid"]["reconnect_limit"]
- The limit for the number of times to reconnect before considering the connection to be failed. -
openstack["block-storage"]["mq"]["qpid"]["reconnect_interval_min"]
- Minimum number of seconds between connection attempts. -
openstack["block-storage"]["mq"]["qpid"]["reconnect_interval_max"]
- Maximum number of seconds between connection attempts. -
openstack["block-storage"]["mq"]["qpid"]["reconnect_interval"]
- Equivalent to setting qpid_reconnect_interval_min and qpid_reconnect_interval_max to the same value. -
openstack["block-storage"]["mq"]["qpid"]["heartbeat"]
- Seconds between heartbeat messages sent to ensure that the connection is still alive. -
openstack["block-storage"]["mq"]["qpid"]["protocol"]
- Protocol to use. Default tcp. -
openstack["block-storage"]["mq"]["qpid"]["tcp_nodelay"]
- Disable the Nagle algorithm. default disabled.
Cinder attributes
openstack["block-storage"]["service_tenant_name"]
- name of tenant to use for the cinder service account in keystoneopenstack["block-storage"]["service_user"]
- cinder service user in keystoneopenstack["block-storage"]["service_role"]
- role for the cinder service user in keystoneopenstack["block-storage"]["notification_driver"]
- Set the notification driver to be used (default to cinder.openstack.common.notifier.rpc_notifier)openstack["block-storage"]["syslog"]["use"]
openstack["block-storage"]["syslog"]["facility"]
openstack["block-storage"]["syslog"]["config_facility"]
openstack["block-storage"]["platform"]
- hash of platform specific package/service names and optionsopenstack["block-storage"]["volume"]["state_path"]
- Top-level directory for maintaining cinder's stateopenstack["block-storage"]["volume"]["driver"]
- Driver to use for volume creationopenstack["block-storage"]["volume"]["volume_clear"]
- Defines the method for clearing volumes on a volume delete possible options: 'zero', 'none', 'shred' (https://review.openstack.org/#/c/12521/)openstack["block-storage"]["volume"]["volume_clear_size"]
- size in MB used to limit the cleared area on deleting a volume, to the first part of the volume only. (default 0 = all MB)openstack["block-storage"]["volume"]["volume_group"]
- Name for the VG that will contain exported volumesopenstack["block-storage"]["voluem"]["volume_group_size"]
- The size (GB) of volume group (default is 40)openstack["block-storage"]["voluem"]["create_volume_group"]
- Create volume group or not when using the LVMISCSIDriver (default is false)openstack["block-storage"]["volume"]["iscsi_helper"]
- ISCSI target user-land tool to useopenstack["block-storage"]["volume"]["iscsi_ip_address"]
- The IP address where the iSCSI daemon is listening onopenstack["block-storage"]["volume"]["iscsi_port"]
- The port where the iSCSI daemon is listening onopenstack["block-storage"]["rbd_pool"]
- RADOS Block Device pool to useopenstack["block-storage"]["rbd_user"]
- User for Cephx Authenticationopenstack["block-storage"]["rbd_secret_uuid"]
- Secret UUID for Cephx Authenticationopenstack["block-storage"]["policy"]["context_is_admin"]
- Define administratorsopenstack["block-storage"]["policy"]["default"]
- Default volume operations ruleopenstack["block-storage"]["policy"]["admin_or_owner"]
- Define an admin or owneropenstack["block-storage"]["policy"]["admin_api"]
- Define api adminopenstack["block-storage"]["netapp"]["protocol"]
- How are we talking to either dfm or filer, http or httpsopenstack["block-storage"]["netapp"]["dfm_hostname"]
- Host or IP of your dfm serveropenstack["block-storage"]["netapp"]["dfm_login"]
- Username for dfmopenstack["block-storage"]["netapp"]["dfm_password"]
- Password for the dfm useropenstack["block-storage"]["netapp"]["dfm_port"]
- Default port for dfmopenstack["block-storage"]["netapp"]["dfm_web_port"]
- Web gui port for wsdl file downloadopenstack["block-storage"]["netapp"]["storage_service"]
- Name of the service in dfpmopenstack["block-storage"]["netapp"]["netapp_server_port"]
- Web admin port of the filer itselfopenstack["block-storage"]["netapp"]["netapp_server_hostname"]
- Hostname of your filer, needs to be resolvableopenstack["block-storage"]["netapp"]["netapp_server_login"]
- Username for netapp fileropenstack["block-storage"]["netapp"]["netapp_server_password"]
- Password for user aboveopenstack["block-storage"]["nfs"]["shares_config"]
- File containing line by line entries of server:exportopenstack["block-storage"]["nfs"]["mount_point_base"]
- Directory to mount NFS exported sharesopenstack["block-storage"]["rpc_thread_pool_size"]
- Size of RPC thread poolopenstack["block-storage"]["rpc_conn_pool_size"]
- Size of RPC connection poolopenstack["block-storage"]["rpc_response_timeout"]
- Seconds to wait for a response from call or multicall
Storwize/SVC attributes
- `openstack['block-storage']['san']['san_ip'] - IP address of SAN controller
- `openstack['block-storage']['san']['san_login'] - Username for SAN controller
- `openstack['block-storage']['san']['san_private_key'] - Filename of private key to use for SSH authentication
- `openstack['block-storage']['storwize']['storwize_svc_volpool_name'] - Storage system storage pool for volumes
- `openstack['block-storage']['storwize']['storwize_svc_vol_rsize'] - Storage system space-efficiency parameter for volumes
- `openstack['block-storage']['storwize']['storwize_svc_vol_warning'] - Storage system threshold for volume capacity warnings
- `openstack['block-storage']['storwize']['storwize_svc_vol_autoexpand'] - Storage system autoexpand parameter for volumes
- `openstack['block-storage']['storwize']['storwize_svc_vol_grainsize'] - Storage system grain size parameter for volumes
- `openstack['block-storage']['storwize']['storwize_svc_vol_compression'] - Storage system compression option for volumes
- `openstack['block-storage']['storwize']['storwize_svc_vol_easytier'] - Enable Easy Tier for volumes
- `openstack['block-storage']['storwize']['storwize_svc_vol_iogrp'] - The I/O group in which to allocate volumes
- `openstack['block-storage']['storwize']['storwize_svc_flashcopy_timeout'] - Maximum number of seconds to wait for FlashCopy to be prepared
- `openstack['block-storage']['storwize']['storwize_svc_connection_protocol'] - Connection protocol (iSCSI/FC)
- `openstack['block-storage']['storwize']['storwize_svc_iscsi_chap_enabled'] - Configure CHAP authentication for iSCSI connections
- `openstack['block-storage']['storwize']['storwize_svc_multipath_enabled'] - Connect with multipath (FC only; iSCSI multipath is controlled by Nova)
- `openstack['block-storage']['storwize']['storwize_svc_multihostmap_enabled'] - Allows vdisk to multi host mapping
Testing
Please refer to the TESTING.md for instructions for testing the cookbook.
Berkshelf
Berks will resolve version requirements and dependencies on first run and
store these in Berksfile.lock. If new cookbooks become available you can run
berks update
to update the references in Berksfile.lock. Berksfile.lock will
be included in stable branches to provide a known good set of dependencies.
Berksfile.lock will not be included in development branches to encourage
development against the latest cookbooks.
License and Author
Author | Justin Shepherd (justin.shepherd@rackspace.com) |
Author | Jason Cannavale (jason.cannavale@rackspace.com) |
Author | Ron Pedde (ron.pedde@rackspace.com) |
Author | Joseph Breu (joseph.breu@rackspace.com) |
Author | William Kelly (william.kelly@rackspace.com) |
Author | Darren Birkett (darren.birkett@rackspace.co.uk) |
Author | Evan Callicoat (evan.callicoat@rackspace.com) |
Author | Matt Ray (matt@opscode.com) |
Author | Jay Pipes (jaypipes@att.com) |
Author | John Dewey (jdewey@att.com) |
Author | Abel Lopez (al592b@att.com) |
Author | Sean Gallagher (sean.gallagher@att.com) |
Author | Ionut Artarisi (iartarisi@suse.cz) |
Author | David Geng (gengjh@cn.ibm.com) |
Author | Salman Baset (sabaset@us.ibm.com) |
Author | Chen Zhiwei (zhiwchen@cn.ibm.com) |
Author | Mark Vanderwiel (vanderwl@us.ibm.com) |
Copyright | Copyright (c) 2012, Rackspace US, Inc. |
Copyright | Copyright (c) 2012-2013, AT&T Services, Inc. |
Copyright | Copyright (c) 2013, Opscode, Inc. |
Copyright | Copyright (c) 2013, SUSE Linux GmbH |
Copyright | Copyright (c) 2013, IBM, Corp. |
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.