From fae499cb7347e8bca1063f96334356282d1fe703 Mon Sep 17 00:00:00 2001 From: Tom Barron Date: Mon, 14 Aug 2017 16:29:07 -0400 Subject: [PATCH] doc migration: configuration reference In accord with the OpenStack documentation migration spec [1], this patch pulls over material from the centralized Configuration Reference so that it will not be lost. As indicated in the spec, dynamic generation of this material will be left for later work. [1] https://specs.openstack.org/openstack/docs-specs/specs/pike/os-manuals-migration.html Closes-Bug: #1706181 Depends-On: Ib0fca0c16e14c05307bfc31ae50c65271b7402f1 Depends-On: Ia750cb049c0f53a234ea70ce1f2bbbb7a2aa9454 Change-Id: I7f3b584ac9907da1f07dedd26324cf4703bc7e6c --- doc/source/_static/manila.conf.sample | 3216 +++++++++++++++++ doc/source/conf.py | 5 + doc/source/configuration/README.rst | 17 - .../configuration/figures/hds_network.jpg | Bin 0 -> 161826 bytes .../configuration/figures/hsp_network.png | Bin 0 -> 155457 bytes .../figures/openstack-spectrumscale-setup.JPG | Bin 0 -> 77400 bytes doc/source/configuration/index.rst | 21 - .../configuration/shared-file-systems.rst | 16 + .../configuration/shared-file-systems/api.rst | 11 + .../shared-file-systems/config-options.rst | 18 + .../shared-file-systems/drivers.rst | 67 + .../drivers/cephfs-native-driver.rst | 294 ++ .../drivers/dell-emc-vmax-driver.rst | 309 ++ .../drivers/emc-isilon-driver.rst | 80 + .../drivers/emc-unity-driver.rst | 265 ++ .../drivers/emc-vnx-driver.rst | 296 ++ .../drivers/generic-driver.rst | 110 + .../drivers/glusterfs-driver.rst | 92 + .../drivers/glusterfs-native-driver.rst | 123 + .../drivers/hdfs-native-driver.rst | 85 + .../drivers/hitachi-hnas-driver.rst | 482 +++ .../drivers/hitachi-hsp-driver.rst | 212 ++ .../drivers/hpe-3par-share-driver.rst | 643 ++++ .../drivers/huawei-nas-driver.rst | 132 + .../drivers/ibm-spectrumscale-driver.rst | 177 + .../drivers/lvm-driver.rst | 89 + .../drivers/maprfs-native-driver.rst | 137 + .../drivers/netapp-cluster-mode-driver.rst | 87 + .../drivers/quobyte-driver.rst | 79 + .../drivers/zfs-on-linux-driver.rst | 190 + .../drivers/zfssa-manila-driver.rst | 123 + .../shared-file-systems/log-files.rst | 30 + .../shared-file-systems/overview.rst | 92 + .../samples/api-paste.ini.rst | 9 + .../shared-file-systems/samples/index.rst | 12 + .../samples/manila.conf.rst | 13 + .../samples/policy.json.rst | 9 + .../samples/rootwrap.conf.rst | 10 + .../configuration/tables/manila-api.inc | 54 + doc/source/configuration/tables/manila-ca.inc | 26 + .../configuration/tables/manila-cephfs.inc | 28 + .../configuration/tables/manila-common.inc | 134 + .../configuration/tables/manila-compute.inc | 34 + .../configuration/tables/manila-emc.inc | 36 + .../configuration/tables/manila-ganesha.inc | 34 + .../configuration/tables/manila-generic.inc | 168 + .../configuration/tables/manila-glusterfs.inc | 42 + .../configuration/tables/manila-hdfs.inc | 32 + .../configuration/tables/manila-hds_hnas.inc | 50 + .../configuration/tables/manila-hds_hsp.inc | 24 + .../configuration/tables/manila-hnas.inc | 22 + .../configuration/tables/manila-hpe3par.inc | 50 + .../configuration/tables/manila-huawei.inc | 22 + .../configuration/tables/manila-lvm.inc | 30 + .../configuration/tables/manila-maprfs.inc | 38 + .../configuration/tables/manila-netapp.inc | 56 + .../configuration/tables/manila-quobyte.inc | 36 + .../configuration/tables/manila-quota.inc | 38 + .../configuration/tables/manila-redis.inc | 36 + .../configuration/tables/manila-san.inc | 26 + .../configuration/tables/manila-scheduler.inc | 40 + .../configuration/tables/manila-share.inc | 80 + .../tables/manila-spectrumscale_ces.inc | 57 + .../tables/manila-spectrumscale_knfs.inc | 61 + .../configuration/tables/manila-tegile.inc | 28 + .../configuration/tables/manila-unity.inc | 26 + .../configuration/tables/manila-vmax.inc | 26 + .../configuration/tables/manila-vnx.inc | 26 + .../configuration/tables/manila-winrm.inc | 34 + .../configuration/tables/manila-zfs.inc | 46 + .../configuration/tables/manila-zfssa.inc | 50 + doc/source/index.rst | 2 +- 72 files changed, 9004 insertions(+), 39 deletions(-) create mode 100644 doc/source/_static/manila.conf.sample delete mode 100644 doc/source/configuration/README.rst create mode 100644 doc/source/configuration/figures/hds_network.jpg create mode 100644 doc/source/configuration/figures/hsp_network.png create mode 100644 doc/source/configuration/figures/openstack-spectrumscale-setup.JPG delete mode 100644 doc/source/configuration/index.rst create mode 100644 doc/source/configuration/shared-file-systems.rst create mode 100644 doc/source/configuration/shared-file-systems/api.rst create mode 100644 doc/source/configuration/shared-file-systems/config-options.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/cephfs-native-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/dell-emc-vmax-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/emc-isilon-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/emc-unity-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/emc-vnx-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/generic-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/glusterfs-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/glusterfs-native-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/hdfs-native-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/hitachi-hnas-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/hitachi-hsp-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/hpe-3par-share-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/huawei-nas-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/ibm-spectrumscale-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/lvm-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/maprfs-native-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/netapp-cluster-mode-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/quobyte-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/zfs-on-linux-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/drivers/zfssa-manila-driver.rst create mode 100644 doc/source/configuration/shared-file-systems/log-files.rst create mode 100644 doc/source/configuration/shared-file-systems/overview.rst create mode 100644 doc/source/configuration/shared-file-systems/samples/api-paste.ini.rst create mode 100644 doc/source/configuration/shared-file-systems/samples/index.rst create mode 100644 doc/source/configuration/shared-file-systems/samples/manila.conf.rst create mode 100644 doc/source/configuration/shared-file-systems/samples/policy.json.rst create mode 100644 doc/source/configuration/shared-file-systems/samples/rootwrap.conf.rst create mode 100644 doc/source/configuration/tables/manila-api.inc create mode 100644 doc/source/configuration/tables/manila-ca.inc create mode 100644 doc/source/configuration/tables/manila-cephfs.inc create mode 100644 doc/source/configuration/tables/manila-common.inc create mode 100644 doc/source/configuration/tables/manila-compute.inc create mode 100644 doc/source/configuration/tables/manila-emc.inc create mode 100644 doc/source/configuration/tables/manila-ganesha.inc create mode 100644 doc/source/configuration/tables/manila-generic.inc create mode 100644 doc/source/configuration/tables/manila-glusterfs.inc create mode 100644 doc/source/configuration/tables/manila-hdfs.inc create mode 100644 doc/source/configuration/tables/manila-hds_hnas.inc create mode 100644 doc/source/configuration/tables/manila-hds_hsp.inc create mode 100644 doc/source/configuration/tables/manila-hnas.inc create mode 100644 doc/source/configuration/tables/manila-hpe3par.inc create mode 100644 doc/source/configuration/tables/manila-huawei.inc create mode 100644 doc/source/configuration/tables/manila-lvm.inc create mode 100644 doc/source/configuration/tables/manila-maprfs.inc create mode 100644 doc/source/configuration/tables/manila-netapp.inc create mode 100644 doc/source/configuration/tables/manila-quobyte.inc create mode 100644 doc/source/configuration/tables/manila-quota.inc create mode 100644 doc/source/configuration/tables/manila-redis.inc create mode 100644 doc/source/configuration/tables/manila-san.inc create mode 100644 doc/source/configuration/tables/manila-scheduler.inc create mode 100644 doc/source/configuration/tables/manila-share.inc create mode 100644 doc/source/configuration/tables/manila-spectrumscale_ces.inc create mode 100644 doc/source/configuration/tables/manila-spectrumscale_knfs.inc create mode 100644 doc/source/configuration/tables/manila-tegile.inc create mode 100644 doc/source/configuration/tables/manila-unity.inc create mode 100644 doc/source/configuration/tables/manila-vmax.inc create mode 100644 doc/source/configuration/tables/manila-vnx.inc create mode 100644 doc/source/configuration/tables/manila-winrm.inc create mode 100644 doc/source/configuration/tables/manila-zfs.inc create mode 100644 doc/source/configuration/tables/manila-zfssa.inc diff --git a/doc/source/_static/manila.conf.sample b/doc/source/_static/manila.conf.sample new file mode 100644 index 0000000000..b67e70a7df --- /dev/null +++ b/doc/source/_static/manila.conf.sample @@ -0,0 +1,3216 @@ +[DEFAULT] + +# +# From manila +# + +# The maximum number of items returned in a single response from a +# collection resource. (integer value) +#osapi_max_limit = 1000 + +# Base URL to be presented to users in links to the Share API (string +# value) +#osapi_share_base_URL = + +# Treat X-Forwarded-For as the canonical remote address. Only enable +# this if you have a sanitizing proxy. (boolean value) +#use_forwarded_for = false + +# Top-level directory for maintaining manila's state. (string value) +#state_path = /var/lib/manila + +# Region name of this node. (string value) +#os_region_name = + +# Warning: Failed to format sample for my_ip +# unhashable type: 'HostAddress' + +# The topic scheduler nodes listen on. (string value) +#scheduler_topic = manila-scheduler + +# The topic share nodes listen on. (string value) +#share_topic = manila-share + +# The topic data nodes listen on. (string value) +#data_topic = manila-data + +# Whether to rate limit the API. (boolean value) +#api_rate_limit = true + +# Specify list of extensions to load when using osapi_share_extension +# option with manila.api.contrib.select_extensions. (list value) +#osapi_share_ext_list = + +# The osapi share extensions to load. (list value) +#osapi_share_extension = manila.api.contrib.standard_extensions + +# The filename to use with sqlite. (string value) +#sqlite_db = manila.sqlite + +# If passed, use synchronous mode for sqlite. (boolean value) +#sqlite_synchronous = true + +# Timeout before idle SQL connections are reaped. (integer value) +#sql_idle_timeout = 3600 + +# Maximum database connection retries during startup. (setting -1 +# implies an infinite retry count). (integer value) +#sql_max_retries = 10 + +# Interval between retries of opening a SQL connection. (integer +# value) +#sql_retry_interval = 10 + +# Full class name for the scheduler manager. (string value) +#scheduler_manager = manila.scheduler.manager.SchedulerManager + +# Full class name for the share manager. (string value) +#share_manager = manila.share.manager.ShareManager + +# Full class name for the data manager. (string value) +#data_manager = manila.data.manager.DataManager + +# Warning: Failed to format sample for host +# unhashable type: 'HostAddress' + +# Availability zone of this node. (string value) +#storage_availability_zone = nova + +# Default share type to use. (string value) +#default_share_type = + +# Default share group type to use. (string value) +#default_share_group_type = + +# Memcached servers or None for in process cache. (list value) +#memcached_servers = + +# Time period to generate share usages for. Time period must be hour, +# day, month or year. (string value) +#share_usage_audit_period = month + +# Deprecated: command to use for running commands as root. (string +# value) +#root_helper = sudo + +# Path to the rootwrap configuration file to use for running commands +# as root. (string value) +#rootwrap_config = + +# Whether to log monkey patching. (boolean value) +#monkey_patch = false + +# List of modules or decorators to monkey patch. (list value) +#monkey_patch_modules = + +# Maximum time since last check-in for up service. (integer value) +#service_down_time = 60 + +# The full class name of the share API class to use. (string value) +#share_api_class = manila.share.api.API + +# The strategy to use for auth. Supports noauth, keystone, and +# deprecated. (string value) +#auth_strategy = keystone + +# A list of share backend names to use. These backend names should be +# backed by a unique [CONFIG] group with its options. (list value) +#enabled_share_backends = + +# Specify list of protocols to be allowed for share creation. +# Available values are '('NFS', 'CIFS', 'GLUSTERFS', 'HDFS', 'CEPHFS', +# 'MAPRFS')' (list value) +#enabled_share_protocols = NFS,CIFS + +# The full class name of the Compute API class to use. (string value) +#compute_api_class = manila.compute.nova.API + +# The back end URL to use for distributed coordination. (string value) +#backend_url = file://$state_path + +# DEPRECATED: Number of seconds between heartbeats for distributed +# coordination. No longer used since distributed coordination manages +# its heartbeat internally. (floating point value) +# This option is deprecated for removal since 5.0.0. +# Its value may be silently ignored in the future. +# Reason: This option is no longer used. +#heartbeat = 1.0 + +# DEPRECATED: Initial number of seconds to wait after failed +# reconnection. No longer used since distributed coordination manages +# its heartbeat internally. (floating point value) +# This option is deprecated for removal since 5.0.0. +# Its value may be silently ignored in the future. +# Reason: This option is no longer used. +#initial_reconnect_backoff = 0.1 + +# DEPRECATED: Maximum number of seconds between sequential +# reconnection retries. No longer used since distributed coordination +# manages its heartbeat internally. (floating point value) +# This option is deprecated for removal since 5.0.0. +# Its value may be silently ignored in the future. +# Reason: This option is no longer used. +#max_reconnect_backoff = 60.0 + +# The backend to use for database. (string value) +#db_backend = sqlalchemy + +# Services to be added to the available pool on create. (boolean +# value) +#enable_new_services = true + +# Template string to be used to generate share names. (string value) +#share_name_template = share-%s + +# Template string to be used to generate share snapshot names. (string +# value) +#share_snapshot_name_template = share-snapshot-%s + +# Driver to use for database access. (string value) +#db_driver = manila.db + +# Whether to make exception message format errors fatal. (boolean +# value) +#fatal_exception_format_errors = false + +# Message minimum life in seconds. (integer value) +#message_ttl = 2592000 + +# Interval between periodic task runs to clean expired messages in +# seconds. (integer value) +#message_reap_interval = 86400 + +# Name of Open vSwitch bridge to use. (string value) +#ovs_integration_bridge = br-int + +# The full class name of the Networking API class to use. (string +# value) +#network_api_class = manila.network.neutron.neutron_network_plugin.NeutronNetworkPlugin + +# vNIC type used for binding. (string value) +# Allowed values: baremetal, normal, direct, direct-physical, macvtap +#neutron_vnic_type = baremetal + +# Host ID to be used when creating neutron port. If not set host is +# set to manila-share host by default. (string value) +#neutron_host_id = tbarron + +# Default Neutron network that will be used for share server creation. +# This opt is used only with class 'NeutronSingleNetworkPlugin'. +# (string value) +#neutron_net_id = + +# Default Neutron subnet that will be used for share server creation. +# Should be assigned to network defined in opt 'neutron_net_id'. This +# opt is used only with class 'NeutronSingleNetworkPlugin'. (string +# value) +#neutron_subnet_id = + +# Gateway address that should be used. Required. (string value) +#standalone_network_plugin_gateway = + +# Network mask that will be used. Can be either decimal like '24' or +# binary like '255.255.255.0'. Required. (string value) +#standalone_network_plugin_mask = + +# Network type, such as 'flat', 'vlan', 'vxlan' or 'gre'. Empty value +# is alias for 'flat'. It will be assigned to share-network and share +# drivers will be able to use this for network interfaces within +# provisioned share servers. Optional. (string value) +# Allowed values: flat, vlan, vxlan, gre +#standalone_network_plugin_network_type = + +# Set it if network has segmentation (VLAN, VXLAN, etc...). It will be +# assigned to share-network and share drivers will be able to use this +# for network interfaces within provisioned share servers. Optional. +# Example: 1001 (integer value) +#standalone_network_plugin_segmentation_id = + +# Can be IP address, range of IP addresses or list of addresses or +# ranges. Contains addresses from IP network that are allowed to be +# used. If empty, then will be assumed that all host addresses from +# network can be used. Optional. Examples: 10.0.0.10 or +# 10.0.0.10-10.0.0.20 or +# 10.0.0.10-10.0.0.20,10.0.0.30-10.0.0.40,10.0.0.50 (list value) +#standalone_network_plugin_allowed_ip_ranges = + +# DEPRECATED: IP version of network. Optional.Allowed values are '4' +# and '6'. Default value is '4'. Note: This option is no longer used +# and has no effect (integer value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: This option has been replaced by +# 'network_plugin_ipv4_enabled' and 'network_plugin_ipv6_enabled' +# options. +#standalone_network_plugin_ip_version = 4 + +# Maximum Transmission Unit (MTU) value of the network. Default value +# is 1500. (integer value) +#standalone_network_plugin_mtu = 1500 + +# Number of shares allowed per project. (integer value) +#quota_shares = 50 + +# Number of share snapshots allowed per project. (integer value) +#quota_snapshots = 50 + +# Number of share gigabytes allowed per project. (integer value) +#quota_gigabytes = 1000 + +# Number of snapshot gigabytes allowed per project. (integer value) +#quota_snapshot_gigabytes = 1000 + +# Number of share-networks allowed per project. (integer value) +#quota_share_networks = 10 + +# Number of share groups allowed. (integer value) +#quota_share_groups = 50 + +# Number of share group snapshots allowed. (integer value) +#quota_share_group_snapshots = 50 + +# Number of seconds until a reservation expires. (integer value) +#reservation_expire = 86400 + +# Count of reservations until usage is refreshed. (integer value) +#until_refresh = 0 + +# Number of seconds between subsequent usage refreshes. (integer +# value) +#max_age = 0 + +# Default driver to use for quota checks. (string value) +#quota_driver = manila.quota.DbQuotaDriver + +# The scheduler host manager class to use. (string value) +#scheduler_host_manager = manila.scheduler.host_manager.HostManager + +# Maximum number of attempts to schedule a share. (integer value) +#scheduler_max_attempts = 3 + +# Which filter class names to use for filtering hosts when not +# specified in the request. (list value) +#scheduler_default_filters = AvailabilityZoneFilter,CapacityFilter,CapabilitiesFilter,DriverFilter,ShareReplicationFilter + +# Which weigher class names to use for weighing hosts. (list value) +#scheduler_default_weighers = CapacityWeigher,GoodnessWeigher + +# Which filter class names to use for filtering hosts creating share +# group when not specified in the request. (list value) +#scheduler_default_share_group_filters = AvailabilityZoneFilter,ConsistentSnapshotFilter + +# Default scheduler driver to use. (string value) +#scheduler_driver = manila.scheduler.drivers.filter.FilterScheduler + +# Absolute path to scheduler configuration JSON file. (string value) +#scheduler_json_config_location = + +# Maximum number of volume gigabytes to allow per host. (integer +# value) +#max_gigabytes = 10000 + +# Multiplier used for weighing share capacity. Negative numbers mean +# to stack vs spread. (floating point value) +#capacity_weight_multiplier = 1.0 + +# Multiplier used for weighing pools which have existing share +# servers. Negative numbers mean to spread vs stack. (floating point +# value) +#pool_weight_multiplier = 1.0 + +# Seconds between nodes reporting state to datastore. (integer value) +#report_interval = 10 + +# Seconds between running periodic tasks. (integer value) +#periodic_interval = 60 + +# Range of seconds to randomly delay when starting the periodic task +# scheduler to reduce stampeding. (Disable by setting to 0) (integer +# value) +#periodic_fuzzy_delay = 60 + +# Warning: Failed to format sample for osapi_share_listen +# unhashable type: 'HostAddress' + +# Port for OpenStack Share API to listen on. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#osapi_share_listen_port = 8786 + +# Number of workers for OpenStack Share API service. (integer value) +#osapi_share_workers = 1 + +# If set to False, then share creation from snapshot will be performed +# on the same host. If set to True, then scheduling step will be used. +# (boolean value) +#use_scheduler_creating_share_from_snapshot = false + +# Directory where Ganesha config files are stored. (string value) +#ganesha_config_dir = /etc/ganesha + +# Path to main Ganesha config file. (string value) +#ganesha_config_path = $ganesha_config_dir/ganesha.conf + +# DEPRECATED: Options to use when exporting a share using ganesha NFS +# server. Note that these defaults can be overridden when a share is +# created by passing metadata with key name export_options. Also note +# the complete set of default ganesha export options is specified in +# ganesha_utils. (GPFS only.) (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: This option is no longer used. +#ganesha_nfs_export_options = maxread = 65536, prefread = 65536 + +# Name of the ganesha nfs service. (string value) +#ganesha_service_name = ganesha.nfsd + +# Location of Ganesha database file. (Ganesha module only.) (string +# value) +#ganesha_db_path = $state_path/manila-ganesha.db + +# Path to directory containing Ganesha export configuration. (Ganesha +# module only.) (string value) +#ganesha_export_dir = $ganesha_config_dir/export.d + +# Path to directory containing Ganesha export block templates. +# (Ganesha module only.) (string value) +#ganesha_export_template_dir = /etc/manila/ganesha-export-templ.d + +# Number of times to attempt to run flakey shell commands. (integer +# value) +#num_shell_tries = 3 + +# The percentage of backend capacity reserved. (integer value) +#reserved_share_percentage = 0 + +# The backend name for a given driver implementation. (string value) +#share_backend_name = + +# Name of the configuration group in the Manila conf file to look for +# network config options.If not set, the share backend's config group +# will be used.If an option is not found within provided group, +# then'DEFAULT' group will be used for search of option. (string +# value) +#network_config_group = + +# There are two possible approaches for share drivers in Manila. First +# is when share driver is able to handle share-servers and second when +# not. Drivers can support either both or only one of these +# approaches. So, set this opt to True if share driver is able to +# handle share servers and it is desired mode else set False. It is +# set to None by default to make this choice intentional. (boolean +# value) +#driver_handles_share_servers = + +# Float representation of the over subscription ratio when thin +# provisioning is involved. Default ratio is 20.0, meaning provisioned +# capacity can be 20 times the total physical capacity. If the ratio +# is 10.5, it means provisioned capacity can be 10.5 times the total +# physical capacity. A ratio of 1.0 means provisioned capacity cannot +# exceed the total physical capacity. A ratio lower than 1.0 is +# invalid. (floating point value) +#max_over_subscription_ratio = 20.0 + +# List of files and folders to be ignored when migrating shares. Items +# should be names (not including any path). (list value) +#migration_ignore_files = lost+found + +# The template for mounting shares for this backend. Must specify the +# executable with all necessary parameters for the protocol supported. +# 'proto' template element may not be required if included in the +# command. 'export' and 'path' template elements are required. It is +# advisable to separate different commands per backend. (string value) +#share_mount_template = mount -vt %(proto)s %(options)s %(export)s %(path)s + +# The template for unmounting shares for this backend. Must specify +# the executable with all necessary parameters for the protocol +# supported. 'path' template element is required. It is advisable to +# separate different commands per backend. (string value) +#share_unmount_template = umount -v %(path)s + +# Protocol access mapping for this backend. Should be a dictionary +# comprised of {'access_type1': ['share_proto1', 'share_proto2'], +# 'access_type2': ['share_proto2', 'share_proto3']}. (dict value) +#protocol_access_mapping = ip:['nfs'],user:['cifs'] + +# DEPRECATED: Specify whether read only access rule mode is supported +# in this backend. Obsolete. (boolean value) +# Deprecated group/name - [DEFAULT]/migration_readonly_support +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: All drivers are now required to support read-only access +# rules. +#migration_readonly_rules_support = true + +# If share driver requires to setup admin network for share, then +# define network plugin config options in some separate config group +# and set its name here. Used only with another option +# 'driver_handles_share_servers' set to 'True'. (string value) +#admin_network_config_group = + +# A string specifying the replication domain that the backend belongs +# to. This option needs to be specified the same in the configuration +# sections of all backends that support replication between each +# other. If this option is not specified in the group, it means that +# replication is not enabled on the backend. (string value) +#replication_domain = + +# String representation for an equation that will be used to filter +# hosts. (string value) +#filter_function = + +# String representation for an equation that will be used to determine +# the goodness of a host. (string value) +#goodness_function = + +# Backend server SSH connection timeout. (integer value) +#ssh_conn_timeout = 60 + +# Minimum number of connections in the SSH pool. (integer value) +#ssh_min_pool_conn = 1 + +# Maximum number of connections in the SSH pool. (integer value) +#ssh_max_pool_conn = 10 + +# The full class name of the Private Data Driver class to use. (string +# value) +#drivers_private_storage_class = manila.share.drivers_private_data.SqlStorageDriver + +# Fully qualified path to the ceph.conf file. (string value) +#cephfs_conf_path = + +# The name of the cluster in use, if it is not the default ('ceph'). +# (string value) +#cephfs_cluster_name = + +# The name of the ceph auth identity to use. (string value) +#cephfs_auth_id = manila + +# Whether to enable snapshots in this driver. (boolean value) +#cephfs_enable_snapshots = false + +# The type of protocol helper to use. Default is CEPHFS. (string +# value) +# Allowed values: CEPHFS, NFS +#cephfs_protocol_helper_type = CEPHFS + +# Whether the NFS-Ganesha server is remote to the driver. (boolean +# value) +#cephfs_ganesha_server_is_remote = false + +# The IP address of the NFS-Ganesha server. (string value) +#cephfs_ganesha_server_ip = + +# The username to authenticate as in the remote NFS-Ganesha server +# host. (string value) +#cephfs_ganesha_server_username = root + +# The path of the driver host's private SSH key file. (string value) +#cephfs_ganesha_path_to_private_key = + +# The password to authenticate as the user in the remote Ganesha +# server host. This is not required if +# 'cephfs_ganesha_path_to_private_key' is configured. (string value) +#cephfs_ganesha_server_password = + +# Linux bridge used by container hypervisor to plug host-side veth to. +# It will be unplugged from here by the driver. (string value) +#container_linux_bridge_name = docker0 + +# OVS bridge to use to plug a container to. (string value) +#container_ovs_bridge_name = br-int + +# Determines whether to allow guest access to CIFS share or not. +# (boolean value) +#container_cifs_guest_ok = true + +# Image to be used for a container-based share server. (string value) +#container_image_name = manila-docker-container + +# Container helper which provides container-related operations to the +# driver. (string value) +#container_helper = manila.share.drivers.container.container_helper.DockerExecHelper + +# Helper which facilitates interaction with share server. (string +# value) +#container_protocol_helper = manila.share.drivers.container.protocol_helper.DockerCIFSHelper + +# Helper which facilitates interaction with storage solution used to +# actually store data. By default LVM is used to provide storage for a +# share. (string value) +#container_storage_helper = manila.share.drivers.container.storage_helper.LVMHelper + +# LVM volume group to use for volumes. This volume group must be +# created by the cloud administrator independently from manila +# operations. (string value) +#container_volume_group = manila_docker_volumes + +# User name for the EMC server. (string value) +#emc_nas_login = + +# Password for the EMC server. (string value) +#emc_nas_password = + +# Warning: Failed to format sample for emc_nas_server +# unhashable type: 'HostAddress' + +# Port number for the EMC server. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#emc_nas_server_port = 8080 + +# Use secure connection to server. (boolean value) +#emc_nas_server_secure = true + +# Share backend. (string value) +# Allowed values: isilon, vnx, unity, vmax +#emc_share_backend = + +# The root directory where shares will be located. (string value) +#emc_nas_root_dir = + +# If set to False the https client will not validate the SSL +# certificate of the backend endpoint. (boolean value) +#emc_ssl_cert_verify = true + +# Can be used to specify a non default path to a CA_BUNDLE file or +# directory with certificates of trusted CAs, which will be used to +# validate the backend. (string value) +#emc_ssl_cert_path = + +# Data mover to host the NAS server. (string value) +#vmax_server_container = + +# Comma separated list of pools that can be used to persist share +# data. (list value) +#vmax_share_data_pools = + +# Comma separated list of ports that can be used for share server +# interfaces. Members of the list can be Unix-style glob expressions. +# (list value) +#vmax_ethernet_ports = + +# Path to smb config. (string value) +#smb_template_config_path = $state_path/smb.conf + +# Volume name template. (string value) +#volume_name_template = manila-share-%s + +# Volume snapshot name template. (string value) +#volume_snapshot_name_template = manila-snapshot-%s + +# Parent path in service instance where shares will be mounted. +# (string value) +#share_mount_path = /shares + +# Maximum time to wait for creating cinder volume. (integer value) +#max_time_to_create_volume = 180 + +# Maximum time to wait for extending cinder volume. (integer value) +#max_time_to_extend_volume = 180 + +# Maximum time to wait for attaching cinder volume. (integer value) +#max_time_to_attach = 120 + +# Path to SMB config in service instance. (string value) +#service_instance_smb_config_path = $share_mount_path/smb.conf + +# Specify list of share export helpers. (list value) +#share_helpers = CIFS=manila.share.drivers.helpers.CIFSHelperIPAccess,NFS=manila.share.drivers.helpers.NFSHelper + +# Filesystem type of the share volume. (string value) +# Allowed values: ext4, ext3 +#share_volume_fstype = ext4 + +# Name or id of cinder volume type which will be used for all volumes +# created by driver. (string value) +#cinder_volume_type = + +# Remote GlusterFS server node's login password. This is not required +# if 'glusterfs_path_to_private_key' is configured. (string value) +# Deprecated group/name - [DEFAULT]/glusterfs_native_server_password +#glusterfs_server_password = + +# Path of Manila host's private SSH key file. (string value) +# Deprecated group/name - [DEFAULT]/glusterfs_native_path_to_private_key +#glusterfs_path_to_private_key = + +# Type of NFS server that mediate access to the Gluster volumes +# (Gluster or Ganesha). (string value) +#glusterfs_nfs_server_type = Gluster + +# Warning: Failed to format sample for glusterfs_ganesha_server_ip +# unhashable type: 'HostAddress' + +# Remote Ganesha server node's username. (string value) +#glusterfs_ganesha_server_username = root + +# Remote Ganesha server node's login password. This is not required if +# 'glusterfs_path_to_private_key' is configured. (string value) +#glusterfs_ganesha_server_password = + +# Specifies GlusterFS share layout, that is, the method of associating +# backing GlusterFS resources to shares. (string value) +#glusterfs_share_layout = + +# Specifies the GlusterFS volume to be mounted on the Manila host. It +# is of the form [remoteuser@]:. (string value) +#glusterfs_target = + +# Base directory containing mount points for Gluster volumes. (string +# value) +#glusterfs_mount_point_base = $state_path/mnt + +# List of GlusterFS servers that can be used to create shares. Each +# GlusterFS server should be of the form [remoteuser@], and +# they are assumed to belong to distinct Gluster clusters. (list +# value) +# Deprecated group/name - [DEFAULT]/glusterfs_targets +#glusterfs_servers = + +# Regular expression template used to filter GlusterFS volumes for +# share creation. The regex template can optionally (ie. with support +# of the GlusterFS backend) contain the #{size} parameter which +# matches an integer (sequence of digits) in which case the value +# shall be interpreted as size of the volume in GB. Examples: "manila- +# share-volume-\d+$", "manila-share-volume-#{size}G-\d+$"; with +# matching volume names, respectively: "manila-share-volume-12", +# "manila-share-volume-3G-13". In latter example, the number that +# matches "#{size}", that is, 3, is an indication that the size of +# volume is 3G. (string value) +#glusterfs_volume_pattern = + +# Warning: Failed to format sample for hdfs_namenode_ip +# unhashable type: 'HostAddress' + +# The port of HDFS namenode service. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#hdfs_namenode_port = 9000 + +# HDFS namenode SSH port. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#hdfs_ssh_port = 22 + +# HDFS namenode ssh login name. (string value) +#hdfs_ssh_name = + +# HDFS namenode SSH login password, This parameter is not necessary, +# if 'hdfs_ssh_private_key' is configured. (string value) +#hdfs_ssh_pw = + +# Path to HDFS namenode SSH private key for login. (string value) +#hdfs_ssh_private_key = + +# Warning: Failed to format sample for hitachi_hnas_ip +# unhashable type: 'HostAddress' + +# HNAS username Base64 String in order to perform tasks such as create +# file-systems and network interfaces. (string value) +# Deprecated group/name - [DEFAULT]/hds_hnas_user +#hitachi_hnas_user = + +# HNAS user password. Required only if private key is not provided. +# (string value) +# Deprecated group/name - [DEFAULT]/hds_hnas_password +#hitachi_hnas_password = + +# Specify which EVS this backend is assigned to. (integer value) +# Deprecated group/name - [DEFAULT]/hds_hnas_evs_id +#hitachi_hnas_evs_id = + +# Warning: Failed to format sample for hitachi_hnas_evs_ip +# unhashable type: 'HostAddress' + +# Warning: Failed to format sample for hitachi_hnas_admin_network_ip +# unhashable type: 'HostAddress' + +# Specify file-system name for creating shares. (string value) +# Deprecated group/name - [DEFAULT]/hds_hnas_file_system_name +#hitachi_hnas_file_system_name = + +# RSA/DSA private key value used to connect into HNAS. Required only +# if password is not provided. (string value) +# Deprecated group/name - [DEFAULT]/hds_hnas_ssh_private_key +#hitachi_hnas_ssh_private_key = + +# Warning: Failed to format sample for hitachi_hnas_cluster_admin_ip0 +# unhashable type: 'HostAddress' + +# The time (in seconds) to wait for stalled HNAS jobs before aborting. +# (integer value) +# Deprecated group/name - [DEFAULT]/hds_hnas_stalled_job_timeout +#hitachi_hnas_stalled_job_timeout = 30 + +# Python class to be used for driver helper. (string value) +# Deprecated group/name - [DEFAULT]/hds_hnas_driver_helper +#hitachi_hnas_driver_helper = manila.share.drivers.hitachi.hnas.ssh.HNASSSHBackend + +# By default, CIFS snapshots are not allowed to be taken when the +# share has clients connected because consistent point-in-time replica +# cannot be guaranteed for all files. Enabling this might cause +# inconsistent snapshots on CIFS shares. (boolean value) +# Deprecated group/name - [DEFAULT]/hds_hnas_allow_cifs_snapshot_while_mounted +#hitachi_hnas_allow_cifs_snapshot_while_mounted = false + +# Warning: Failed to format sample for hitachi_hsp_host +# unhashable type: 'HostAddress' + +# HSP username to perform tasks such as create filesystems and shares. +# (string value) +#hitachi_hsp_username = + +# HSP password for the username provided. (string value) +#hitachi_hsp_password = + +# 3PAR WSAPI Server Url like https://<3par ip>:8080/api/v1 (string +# value) +# Deprecated group/name - [DEFAULT]/hp3par_api_url +#hpe3par_api_url = + +# 3PAR username with the 'edit' role (string value) +# Deprecated group/name - [DEFAULT]/hp3par_username +#hpe3par_username = + +# 3PAR password for the user specified in hpe3par_username (string +# value) +# Deprecated group/name - [DEFAULT]/hp3par_password +#hpe3par_password = + +# Warning: Failed to format sample for hpe3par_san_ip +# unhashable type: 'HostAddress' + +# Username for SAN controller (string value) +# Deprecated group/name - [DEFAULT]/hp3par_san_login +#hpe3par_san_login = + +# Password for SAN controller (string value) +# Deprecated group/name - [DEFAULT]/hp3par_san_password +#hpe3par_san_password = + +# SSH port to use with SAN (port value) +# Minimum value: 0 +# Maximum value: 65535 +# Deprecated group/name - [DEFAULT]/hp3par_san_ssh_port +#hpe3par_san_ssh_port = 22 + +# The File Provisioning Group (FPG) to use (FPG) +# Deprecated group/name - [DEFAULT]/hp3par_fpg +#hpe3par_fpg = + +# Use one filestore per share (boolean value) +# Deprecated group/name - [DEFAULT]/hp3par_fstore_per_share +#hpe3par_fstore_per_share = false + +# Require IP access rules for CIFS (in addition to user) (boolean +# value) +#hpe3par_require_cifs_ip = false + +# Enable HTTP debugging to 3PAR (boolean value) +# Deprecated group/name - [DEFAULT]/hp3par_debug +#hpe3par_debug = false + +# File system admin user name for CIFS. (string value) +# Deprecated group/name - [DEFAULT]/hp3par_cifs_admin_access_username +#hpe3par_cifs_admin_access_username = + +# File system admin password for CIFS. (string value) +# Deprecated group/name - [DEFAULT]/hp3par_cifs_admin_access_password +#hpe3par_cifs_admin_access_password = + +# File system domain for the CIFS admin user. (string value) +# Deprecated group/name - [DEFAULT]/hp3par_cifs_admin_access_domain +#hpe3par_cifs_admin_access_domain = LOCAL_CLUSTER + +# The path where shares will be mounted when deleting nested file +# trees. (string value) +# Deprecated group/name - [DEFAULT]/hpe3par_share_mount_path +#hpe3par_share_mount_path = /mnt/ + +# The configuration file for the Manila Huawei driver. (string value) +#manila_huawei_conf_file = /etc/manila/manila_huawei_conf.xml + +# Warning: Failed to format sample for gpfs_share_export_ip +# unhashable type: 'HostAddress' + +# Base folder where exported shares are located. (string value) +#gpfs_mount_point_base = $state_path/mnt + +# NFS Server type. Valid choices are "CES" (Ganesha NFS) or "KNFS" +# (Kernel NFS). (string value) +#gpfs_nfs_server_type = CES + +# A list of the fully qualified NFS server names that make up the +# OpenStack Manila configuration. (list value) +#gpfs_nfs_server_list = + +# True:when Manila services are running on one of the Spectrum Scale +# node. False:when Manila services are not running on any of the +# Spectrum Scale node. (boolean value) +#is_gpfs_node = false + +# GPFS server SSH port. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#gpfs_ssh_port = 22 + +# GPFS server SSH login name. (string value) +#gpfs_ssh_login = + +# GPFS server SSH login password. The password is not needed, if +# 'gpfs_ssh_private_key' is configured. (string value) +#gpfs_ssh_password = + +# Path to GPFS server SSH private key for login. (string value) +#gpfs_ssh_private_key = + +# Specify list of share export helpers. (list value) +#gpfs_share_helpers = KNFS=manila.share.drivers.ibm.gpfs.KNFSHelper,CES=manila.share.drivers.ibm.gpfs.CESHelper + +# DEPRECATED: Options to use when exporting a share using kernel NFS +# server. Note that these defaults can be overridden when a share is +# created by passing metadata with key name export_options. (string +# value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: This option isn't used any longer. Please use share-type +# extra specs for export options. +#knfs_export_options = rw,sync,no_root_squash,insecure,no_wdelay,no_subtree_check + +# The list of IPs or hostnames of nodes where mapr-core is installed. +# (list value) +#maprfs_clinode_ip = + +# CLDB node SSH port. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#maprfs_ssh_port = 22 + +# Cluster admin user ssh login name. (string value) +#maprfs_ssh_name = mapr + +# Cluster node SSH login password, This parameter is not necessary, if +# 'maprfs_ssh_private_key' is configured. (string value) +#maprfs_ssh_pw = + +# Path to SSH private key for login. (string value) +#maprfs_ssh_private_key = + +# Path in MapRFS where share volumes must be created. (string value) +#maprfs_base_volume_dir = / + +# The list of IPs or hostnames of ZooKeeper nodes. (list value) +#maprfs_zookeeper_ip = + +# The list of IPs or hostnames of CLDB nodes. (list value) +#maprfs_cldb_ip = + +# Specify whether existing volume should be renamed when start +# managing. (boolean value) +#maprfs_rename_managed_volume = true + +# Base folder where exported shares are located. (string value) +#lvm_share_export_root = $state_path/mnt + +# DEPRECATED: IP to be added to export string. (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Use lvm_share_export_ips instead. +#lvm_share_export_ip = + +# List of IPs to export shares. (list value) +#lvm_share_export_ips = + +# If set, create LVMs with multiple mirrors. Note that this requires +# lvm_mirrors + 2 PVs with available space. (integer value) +#lvm_share_mirrors = 0 + +# Name for the VG that will contain exported shares. (string value) +#lvm_share_volume_group = lvm-shares + +# Specify list of share export helpers. (list value) +#lvm_share_helpers = CIFS=manila.share.drivers.helpers.CIFSHelperUserAccess,NFS=manila.share.drivers.helpers.NFSHelper + +# The storage family type used on the storage system; valid values +# include ontap_cluster for using clustered Data ONTAP. (string value) +#netapp_storage_family = ontap_cluster + +# Warning: Failed to format sample for netapp_server_hostname +# unhashable type: 'HostAddress' + +# The TCP port to use for communication with the storage system or +# proxy server. If not specified, Data ONTAP drivers will use 80 for +# HTTP and 443 for HTTPS. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#netapp_server_port = + +# The transport protocol used when communicating with the storage +# system or proxy server. Valid values are http or https. (string +# value) +# Deprecated group/name - [DEFAULT]/netapp_nas_transport_type +#netapp_transport_type = http + +# Administrative user account name used to access the storage system. +# (string value) +# Deprecated group/name - [DEFAULT]/netapp_nas_login +#netapp_login = + +# Password for the administrative user account specified in the +# netapp_login option. (string value) +# Deprecated group/name - [DEFAULT]/netapp_nas_password +#netapp_password = + +# The NFS protocol versions that will be enabled. Supported values +# include nfs3, nfs4.0, nfs4.1. This option only applies when the +# option driver_handles_share_servers is set to True. (list value) +#netapp_enabled_share_protocols = nfs3,nfs4.0 + +# NetApp volume name template. (string value) +# Deprecated group/name - [DEFAULT]/netapp_nas_volume_name_template +#netapp_volume_name_template = share_%(share_id)s + +# Name template to use for new Vserver. (string value) +#netapp_vserver_name_template = os_%s + +# NetApp QoS policy group name template. (string value) +#netapp_qos_policy_group_name_template = qos_share_%(share_id)s + +# Pattern for overriding the selection of network ports on which to +# create Vserver LIFs. (string value) +#netapp_port_name_search_pattern = (.*) + +# Logical interface (LIF) name template (string value) +#netapp_lif_name_template = os_%(net_allocation_id)s + +# Pattern for searching available aggregates for provisioning. (string +# value) +#netapp_aggregate_name_search_pattern = (.*) + +# Name of aggregate to create Vserver root volumes on. This option +# only applies when the option driver_handles_share_servers is set to +# True. (string value) +#netapp_root_volume_aggregate = + +# Root volume name. (string value) +# Deprecated group/name - [DEFAULT]/netapp_root_volume_name +#netapp_root_volume = root + +# The percentage of share space set aside as reserve for snapshot +# usage; valid values range from 0 to 90. (integer value) +# Minimum value: 0 +# Maximum value: 90 +#netapp_volume_snapshot_reserve_percent = 5 + +# The maximum time in seconds to wait for existing snapmirror +# transfers to complete before aborting when promoting a replica. +# (integer value) +# Minimum value: 0 +#netapp_snapmirror_quiesce_timeout = 3600 + +# The maximum time in seconds to wait for the completion of a volume +# move operation after the cutover was triggered. (integer value) +# Minimum value: 0 +#netapp_volume_move_cutover_timeout = 3600 + +# Warning: Failed to format sample for nexenta_host +# unhashable type: 'HostAddress' + +# Port to connect to Nexenta REST API server. (integer value) +#nexenta_rest_port = 8457 + +# Number of retries for unsuccessful API calls. (integer value) +#nexenta_retry_count = 6 + +# Use http or https for REST connection (default auto). (string value) +# Allowed values: http, https, auto +#nexenta_rest_protocol = auto + +# User name to connect to Nexenta SA. (string value) +#nexenta_user = admin + +# Password to connect to Nexenta SA. (string value) +#nexenta_password = + +# Volume name on NexentaStor. (string value) +#nexenta_volume = volume1 + +# Pool name on NexentaStor. (string value) +#nexenta_pool = pool1 + +# On if share over NFS is enabled. (boolean value) +#nexenta_nfs = true + +# Parent folder on NexentaStor. (string value) +#nexenta_nfs_share = nfs_share + +# Compression value for new ZFS folders. (string value) +# Allowed values: on, off, gzip, gzip-1, gzip-2, gzip-3, gzip-4, gzip-5, gzip-6, gzip-7, gzip-8, gzip-9, lzjb, zle, lz4 +#nexenta_dataset_compression = on + +# Deduplication value for new ZFS folders. (string value) +# Allowed values: on, off, sha256, verify, sha256, verify +#nexenta_dataset_dedupe = off + +# If True shares will not be space guaranteed and overprovisioning +# will be enabled. (boolean value) +#nexenta_thin_provisioning = true + +# Base directory that contains NFS share mount points. (string value) +#nexenta_mount_point_base = $state_path/mnt + +# The URL to manage QNAP Storage. (string value) +#qnap_management_url = + +# Warning: Failed to format sample for qnap_share_ip +# unhashable type: 'HostAddress' + +# Username for QNAP storage. (string value) +#qnap_nas_login = + +# Password for QNAP storage. (string value) +#qnap_nas_password = + +# Pool within which QNAP shares must be created. (string value) +#qnap_poolname = + +# URL of the Quobyte API server (http or https) (string value) +#quobyte_api_url = + +# The X.509 CA file to verify the server cert. (string value) +#quobyte_api_ca = + +# Actually deletes shares (vs. unexport) (boolean value) +#quobyte_delete_shares = false + +# Username for Quobyte API server. (string value) +#quobyte_api_username = admin + +# Password for Quobyte API server (string value) +#quobyte_api_password = quobyte + +# Name of volume configuration used for new shares. (string value) +#quobyte_volume_configuration = BASE + +# Default owning user for new volumes. (string value) +#quobyte_default_volume_user = root + +# Default owning group for new volumes. (string value) +#quobyte_default_volume_group = root + +# User in service instance that will be used for authentication. +# (string value) +#service_instance_user = + +# Password for service instance user. (string value) +#service_instance_password = + +# Path to host's private key. (string value) +#path_to_private_key = + +# Maximum time in seconds to wait for creating service instance. +# (integer value) +#max_time_to_build_instance = 300 + +# Name or ID of service instance in Nova to use for share exports. +# Used only when share servers handling is disabled. (string value) +#service_instance_name_or_id = + +# Warning: Failed to format sample for service_net_name_or_ip +# unhashable type: 'HostAddress' + +# Warning: Failed to format sample for tenant_net_name_or_ip +# unhashable type: 'HostAddress' + +# Name of image in Glance, that will be used for service instance +# creation. Only used if driver_handles_share_servers=True. (string +# value) +#service_image_name = manila-service-image + +# Name of service instance. Only used if +# driver_handles_share_servers=True. (string value) +#service_instance_name_template = manila_service_instance_%s + +# Keypair name that will be created and used for service instances. +# Only used if driver_handles_share_servers=True. (string value) +#manila_service_keypair_name = manila-service + +# Path to hosts public key. Only used if +# driver_handles_share_servers=True. (string value) +#path_to_public_key = ~/.ssh/id_rsa.pub + +# Security group name, that will be used for service instance +# creation. Only used if driver_handles_share_servers=True. (string +# value) +#service_instance_security_group = manila-service + +# ID of flavor, that will be used for service instance creation. Only +# used if driver_handles_share_servers=True. (integer value) +#service_instance_flavor_id = 100 + +# Name of manila service network. Used only with Neutron. Only used if +# driver_handles_share_servers=True. (string value) +#service_network_name = manila_service_network + +# CIDR of manila service network. Used only with Neutron and if +# driver_handles_share_servers=True. (string value) +#service_network_cidr = 10.254.0.0/16 + +# This mask is used for dividing service network into subnets, IP +# capacity of subnet with this mask directly defines possible amount +# of created service VMs per tenant's subnet. Used only with Neutron +# and if driver_handles_share_servers=True. (integer value) +#service_network_division_mask = 28 + +# Vif driver. Used only with Neutron and if +# driver_handles_share_servers=True. (string value) +#interface_driver = manila.network.linux.interface.OVSInterfaceDriver + +# Attach share server directly to share network. Used only with +# Neutron and if driver_handles_share_servers=True. (boolean value) +#connect_share_server_to_tenant_network = false + +# ID of neutron network used to communicate with admin network, to +# create additional admin export locations on. (string value) +#admin_network_id = + +# ID of neutron subnet used to communicate with admin network, to +# create additional admin export locations on. Related to +# 'admin_network_id'. (string value) +#admin_subnet_id = + +# Warning: Failed to format sample for tegile_nas_server +# unhashable type: 'HostAddress' + +# User name for the Tegile NAS server. (string value) +#tegile_nas_login = + +# Password for the Tegile NAS server. (string value) +#tegile_nas_password = + +# Create shares in this project (string value) +#tegile_default_project = + +# Path to the x509 certificate used for accessing the serviceinstance. +# (string value) +#winrm_cert_pem_path = ~/.ssl/cert.pem + +# Path to the x509 certificate key. (string value) +#winrm_cert_key_pem_path = ~/.ssl/key.pem + +# Use x509 certificates in order to authenticate to theservice +# instance. (boolean value) +#winrm_use_cert_based_auth = false + +# WinRM connection timeout. (integer value) +#winrm_conn_timeout = 60 + +# WinRM operation timeout. (integer value) +#winrm_operation_timeout = 60 + +# WinRM retry count. (integer value) +#winrm_retry_count = 3 + +# WinRM retry interval in seconds (integer value) +#winrm_retry_interval = 5 + +# Warning: Failed to format sample for zfs_share_export_ip +# unhashable type: 'HostAddress' + +# Warning: Failed to format sample for zfs_service_ip +# unhashable type: 'HostAddress' + +# Specify list of zpools that are allowed to be used by backend. Can +# contain nested datasets. Examples: Without nested dataset: +# 'zpool_name'. With nested dataset: 'zpool_name/nested_dataset_name'. +# Required. (list value) +#zfs_zpool_list = + +# Define here list of options that should be applied for each dataset +# creation if needed. Example: compression=gzip,dedup=off. Note that, +# for secondary replicas option 'readonly' will be set to 'on' and for +# active replicas to 'off' in any way. Also, 'quota' will be equal to +# share size. Optional. (list value) +#zfs_dataset_creation_options = + +# Prefix to be used in each dataset name. Optional. (string value) +#zfs_dataset_name_prefix = manila_share_ + +# Prefix to be used in each dataset snapshot name. Optional. (string +# value) +#zfs_dataset_snapshot_name_prefix = manila_share_snapshot_ + +# Remote ZFS storage hostname that should be used for SSH'ing. +# Optional. (boolean value) +#zfs_use_ssh = false + +# SSH user that will be used in 2 cases: 1) By manila-share service in +# case it is located on different host than its ZFS storage. 2) By +# manila-share services with other ZFS backends that perform +# replication. It is expected that SSH'ing will be key-based, +# passwordless. This user should be passwordless sudoer. Optional. +# (string value) +#zfs_ssh_username = + +# Password for user that is used for SSH'ing ZFS storage host. Not +# used for replication operations. They require passwordless SSH +# access. Optional. (string value) +#zfs_ssh_user_password = + +# Path to SSH private key that should be used for SSH'ing ZFS storage +# host. Not used for replication operations. Optional. (string value) +#zfs_ssh_private_key_path = + +# Specify list of share export helpers for ZFS storage. It should look +# like following: +# 'FOO_protocol=foo.FooClass,BAR_protocol=bar.BarClass'. Required. +# (list value) +#zfs_share_helpers = NFS=manila.share.drivers.zfsonlinux.utils.NFSviaZFSHelper + +# Set snapshot prefix for usage in ZFS replication. Required. (string +# value) +#zfs_replica_snapshot_prefix = tmp_snapshot_for_replication_ + +# Set snapshot prefix for usage in ZFS migration. Required. (string +# value) +#zfs_migration_snapshot_prefix = tmp_snapshot_for_share_migration_ + +# Warning: Failed to format sample for zfssa_host +# unhashable type: 'HostAddress' + +# Warning: Failed to format sample for zfssa_data_ip +# unhashable type: 'HostAddress' + +# ZFSSA management authorized username. (string value) +#zfssa_auth_user = + +# ZFSSA management authorized userpassword. (string value) +#zfssa_auth_password = + +# ZFSSA storage pool name. (string value) +#zfssa_pool = + +# ZFSSA project name. (string value) +#zfssa_project = + +# Controls checksum used for data blocks. (string value) +#zfssa_nas_checksum = fletcher4 + +# Data compression-off, lzjb, gzip-2, gzip, gzip-9. (string value) +#zfssa_nas_compression = off + +# Controls behavior when servicing synchronous writes. (string value) +#zfssa_nas_logbias = latency + +# Location of project in ZFS/SA. (string value) +#zfssa_nas_mountpoint = + +# Controls whether a share quota includes snapshot. (string value) +#zfssa_nas_quota_snap = true + +# Controls whether file ownership can be changed. (string value) +#zfssa_nas_rstchown = true + +# Controls whether the share is scanned for viruses. (string value) +#zfssa_nas_vscan = false + +# REST connection timeout (in seconds). (string value) +#zfssa_rest_timeout = + +# Driver policy for share manage. A strict policy checks for a schema +# named manila_managed, and makes sure its value is true. A loose +# policy does not check for the schema. (string value) +# Allowed values: loose, strict +#zfssa_manage_policy = loose + +# Whether to enable pre hooks or not. (boolean value) +#enable_pre_hooks = false + +# Whether to enable post hooks or not. (boolean value) +#enable_post_hooks = false + +# Whether to enable periodic hooks or not. (boolean value) +#enable_periodic_hooks = false + +# Whether to suppress pre hook errors (allow driver perform actions) +# or not. (boolean value) +#suppress_pre_hooks_errors = false + +# Whether to suppress post hook errors (allow driver's results to pass +# through) or not. (boolean value) +#suppress_post_hooks_errors = false + +# Interval in seconds between execution of periodic hooks. Used when +# option 'enable_periodic_hooks' is set to True. Default is 300. +# (floating point value) +#periodic_hooks_interval = 300.0 + +# Driver to use for share creation. (string value) +#share_driver = manila.share.drivers.generic.GenericShareDriver + +# Driver(s) to perform some additional actions before and after share +# driver actions and on a periodic basis. Default is []. (list value) +#hook_drivers = + +# Whether share servers will be deleted on deletion of the last share. +# (boolean value) +#delete_share_server_with_last_share = false + +# If set to True, then manila will deny access and remove all access +# rules on share unmanage.If set to False - nothing will be changed. +# (boolean value) +#unmanage_remove_access_rules = false + +# If set to True, then Manila will delete all share servers which were +# unused more than specified time .If set to False - automatic +# deletion of share servers will be disabled. (boolean value) +#automatic_share_server_cleanup = true + +# Unallocated share servers reclamation time interval (minutes). +# Minimum value is 10 minutes, maximum is 60 minutes. The reclamation +# function is run every 10 minutes and delete share servers which were +# unused more than unused_share_server_cleanup_interval option +# defines. This value reflects the shortest time Manila will wait for +# a share server to go unutilized before deleting it. (integer value) +# Minimum value: 10 +# Maximum value: 60 +#unused_share_server_cleanup_interval = 10 + +# This value, specified in seconds, determines how often the share +# manager will poll for the health (replica_state) of each replica +# instance. (integer value) +#replica_state_update_interval = 300 + +# This value, specified in seconds, determines how often the share +# manager will poll the driver to perform the next step of migration +# in the storage backend, for a migrating share. (integer value) +#migration_driver_continue_update_interval = 60 + +# This value, specified in seconds, determines how often the share +# manager will poll the driver to update the share usage size in the +# storage backend, for shares in that backend. (integer value) +#share_usage_size_update_interval = 300 + +# If set to True, share usage size will be polled for in the interval +# specified with "share_usage_size_update_interval". Usage data can be +# consumed by telemetry integration. If telemetry is not configured, +# this option must be set to False. If set to False - gathering share +# usage size will be disabled. (boolean value) +#enable_gathering_share_usage_size = false + +# The full class name of the Volume API class to use. (string value) +#volume_api_class = manila.volume.cinder.API + +# Sets the value of TCP_KEEPALIVE (True/False) for each server socket. +# (boolean value) +#tcp_keepalive = true + +# Sets the value of TCP_KEEPINTVL in seconds for each server socket. +# Not supported on OS X. (integer value) +#tcp_keepalive_interval = + +# Sets the value of TCP_KEEPCNT for each server socket. Not supported +# on OS X. (integer value) +#tcp_keepalive_count = + +# If set to true, the logging level will be set to DEBUG instead of +# the default INFO level. (boolean value) +# Note: This option can be changed without restarting. +#debug = false + +# The name of a logging configuration file. This file is appended to +# any existing logging configuration files. For details about logging +# configuration files, see the Python logging module documentation. +# Note that when logging configuration files are used then all logging +# configuration is set in the configuration file and other logging +# configuration options are ignored (for example, +# logging_context_format_string). (string value) +# Note: This option can be changed without restarting. +# Deprecated group/name - [DEFAULT]/log_config +#log_config_append = + +# Defines the format string for %%(asctime)s in log records. Default: +# %(default)s . This option is ignored if log_config_append is set. +# (string value) +#log_date_format = %Y-%m-%d %H:%M:%S + +# (Optional) Name of log file to send logging output to. If no default +# is set, logging will go to stderr as defined by use_stderr. This +# option is ignored if log_config_append is set. (string value) +# Deprecated group/name - [DEFAULT]/logfile +#log_file = + +# (Optional) The base directory used for relative log_file paths. +# This option is ignored if log_config_append is set. (string value) +# Deprecated group/name - [DEFAULT]/logdir +#log_dir = + +# Uses logging handler designed to watch file system. When log file is +# moved or removed this handler will open a new log file with +# specified path instantaneously. It makes sense only if log_file +# option is specified and Linux platform is used. This option is +# ignored if log_config_append is set. (boolean value) +#watch_log_file = false + +# Use syslog for logging. Existing syslog format is DEPRECATED and +# will be changed later to honor RFC5424. This option is ignored if +# log_config_append is set. (boolean value) +#use_syslog = false + +# Enable journald for logging. If running in a systemd environment you +# may wish to enable journal support. Doing so will use the journal +# native protocol which includes structured metadata in addition to +# log messages.This option is ignored if log_config_append is set. +# (boolean value) +#use_journal = false + +# Syslog facility to receive log lines. This option is ignored if +# log_config_append is set. (string value) +#syslog_log_facility = LOG_USER + +# Log output to standard error. This option is ignored if +# log_config_append is set. (boolean value) +#use_stderr = false + +# Format string to use for log messages with context. (string value) +#logging_context_format_string = %(asctime)s.%(msecs)03d %(process)d %(levelname)s %(name)s [%(request_id)s %(user_identity)s] %(instance)s%(message)s + +# Format string to use for log messages when context is undefined. +# (string value) +#logging_default_format_string = %(asctime)s.%(msecs)03d %(process)d %(levelname)s %(name)s [-] %(instance)s%(message)s + +# Additional data to append to log message when logging level for the +# message is DEBUG. (string value) +#logging_debug_format_suffix = %(funcName)s %(pathname)s:%(lineno)d + +# Prefix each line of exception output with this format. (string +# value) +#logging_exception_prefix = %(asctime)s.%(msecs)03d %(process)d ERROR %(name)s %(instance)s + +# Defines the format string for %(user_identity)s that is used in +# logging_context_format_string. (string value) +#logging_user_identity_format = %(user)s %(tenant)s %(domain)s %(user_domain)s %(project_domain)s + +# List of package logging levels in logger=LEVEL pairs. This option is +# ignored if log_config_append is set. (list value) +#default_log_levels = amqp=WARN,amqplib=WARN,boto=WARN,qpid=WARN,sqlalchemy=WARN,suds=INFO,oslo.messaging=INFO,oslo_messaging=INFO,iso8601=WARN,requests.packages.urllib3.connectionpool=WARN,urllib3.connectionpool=WARN,websocket=WARN,requests.packages.urllib3.util.retry=WARN,urllib3.util.retry=WARN,keystonemiddleware=WARN,routes.middleware=WARN,stevedore=WARN,taskflow=WARN,keystoneauth=WARN,oslo.cache=INFO,dogpile.core.dogpile=INFO + +# Enables or disables publication of error events. (boolean value) +#publish_errors = false + +# The format for an instance that is passed with the log message. +# (string value) +#instance_format = "[instance: %(uuid)s] " + +# The format for an instance UUID that is passed with the log message. +# (string value) +#instance_uuid_format = "[instance: %(uuid)s] " + +# Interval, number of seconds, of log rate limiting. (integer value) +#rate_limit_interval = 0 + +# Maximum number of logged messages per rate_limit_interval. (integer +# value) +#rate_limit_burst = 0 + +# Log level name used by rate limiting: CRITICAL, ERROR, INFO, +# WARNING, DEBUG or empty string. Logs with level greater or equal to +# rate_limit_except_level are not filtered. An empty string means that +# all levels are filtered. (string value) +#rate_limit_except_level = CRITICAL + +# Enables or disables fatal status of deprecations. (boolean value) +#fatal_deprecations = false + +# +# From oslo.messaging +# + +# Size of RPC connection pool. (integer value) +#rpc_conn_pool_size = 30 + +# The pool size limit for connections expiration policy (integer +# value) +#conn_pool_min_size = 2 + +# The time-to-live in sec of idle connections in the pool (integer +# value) +#conn_pool_ttl = 1200 + +# ZeroMQ bind address. Should be a wildcard (*), an ethernet +# interface, or IP. The "host" option should point or resolve to this +# address. (string value) +#rpc_zmq_bind_address = * + +# MatchMaker driver. (string value) +# Allowed values: redis, sentinel, dummy +#rpc_zmq_matchmaker = redis + +# Number of ZeroMQ contexts, defaults to 1. (integer value) +#rpc_zmq_contexts = 1 + +# Maximum number of ingress messages to locally buffer per topic. +# Default is unlimited. (integer value) +#rpc_zmq_topic_backlog = + +# Directory for holding IPC sockets. (string value) +#rpc_zmq_ipc_dir = /var/run/openstack + +# Name of this node. Must be a valid hostname, FQDN, or IP address. +# Must match "host" option, if running Nova. (string value) +#rpc_zmq_host = localhost + +# Number of seconds to wait before all pending messages will be sent +# after closing a socket. The default value of -1 specifies an +# infinite linger period. The value of 0 specifies no linger period. +# Pending messages shall be discarded immediately when the socket is +# closed. Positive values specify an upper bound for the linger +# period. (integer value) +# Deprecated group/name - [DEFAULT]/rpc_cast_timeout +#zmq_linger = -1 + +# The default number of seconds that poll should wait. Poll raises +# timeout exception when timeout expired. (integer value) +#rpc_poll_timeout = 1 + +# Expiration timeout in seconds of a name service record about +# existing target ( < 0 means no timeout). (integer value) +#zmq_target_expire = 300 + +# Update period in seconds of a name service record about existing +# target. (integer value) +#zmq_target_update = 180 + +# Use PUB/SUB pattern for fanout methods. PUB/SUB always uses proxy. +# (boolean value) +#use_pub_sub = false + +# Use ROUTER remote proxy. (boolean value) +#use_router_proxy = false + +# This option makes direct connections dynamic or static. It makes +# sense only with use_router_proxy=False which means to use direct +# connections for direct message types (ignored otherwise). (boolean +# value) +#use_dynamic_connections = false + +# How many additional connections to a host will be made for failover +# reasons. This option is actual only in dynamic connections mode. +# (integer value) +#zmq_failover_connections = 2 + +# Minimal port number for random ports range. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#rpc_zmq_min_port = 49153 + +# Maximal port number for random ports range. (integer value) +# Minimum value: 1 +# Maximum value: 65536 +#rpc_zmq_max_port = 65536 + +# Number of retries to find free port number before fail with +# ZMQBindError. (integer value) +#rpc_zmq_bind_port_retries = 100 + +# Default serialization mechanism for serializing/deserializing +# outgoing/incoming messages (string value) +# Allowed values: json, msgpack +#rpc_zmq_serialization = json + +# This option configures round-robin mode in zmq socket. True means +# not keeping a queue when server side disconnects. False means to +# keep queue and messages even if server is disconnected, when the +# server appears we send all accumulated messages to it. (boolean +# value) +#zmq_immediate = true + +# Enable/disable TCP keepalive (KA) mechanism. The default value of -1 +# (or any other negative value) means to skip any overrides and leave +# it to OS default; 0 and 1 (or any other positive value) mean to +# disable and enable the option respectively. (integer value) +#zmq_tcp_keepalive = -1 + +# The duration between two keepalive transmissions in idle condition. +# The unit is platform dependent, for example, seconds in Linux, +# milliseconds in Windows etc. The default value of -1 (or any other +# negative value and 0) means to skip any overrides and leave it to OS +# default. (integer value) +#zmq_tcp_keepalive_idle = -1 + +# The number of retransmissions to be carried out before declaring +# that remote end is not available. The default value of -1 (or any +# other negative value and 0) means to skip any overrides and leave it +# to OS default. (integer value) +#zmq_tcp_keepalive_cnt = -1 + +# The duration between two successive keepalive retransmissions, if +# acknowledgement to the previous keepalive transmission is not +# received. The unit is platform dependent, for example, seconds in +# Linux, milliseconds in Windows etc. The default value of -1 (or any +# other negative value and 0) means to skip any overrides and leave it +# to OS default. (integer value) +#zmq_tcp_keepalive_intvl = -1 + +# Maximum number of (green) threads to work concurrently. (integer +# value) +#rpc_thread_pool_size = 100 + +# Expiration timeout in seconds of a sent/received message after which +# it is not tracked anymore by a client/server. (integer value) +#rpc_message_ttl = 300 + +# Wait for message acknowledgements from receivers. This mechanism +# works only via proxy without PUB/SUB. (boolean value) +#rpc_use_acks = false + +# Number of seconds to wait for an ack from a cast/call. After each +# retry attempt this timeout is multiplied by some specified +# multiplier. (integer value) +#rpc_ack_timeout_base = 15 + +# Number to multiply base ack timeout by after each retry attempt. +# (integer value) +#rpc_ack_timeout_multiplier = 2 + +# Default number of message sending attempts in case of any problems +# occurred: positive value N means at most N retries, 0 means no +# retries, None or -1 (or any other negative values) mean to retry +# forever. This option is used only if acknowledgments are enabled. +# (integer value) +#rpc_retry_attempts = 3 + +# List of publisher hosts SubConsumer can subscribe on. This option +# has higher priority then the default publishers list taken from the +# matchmaker. (list value) +#subscribe_on = + +# Size of executor thread pool when executor is threading or eventlet. +# (integer value) +# Deprecated group/name - [DEFAULT]/rpc_thread_pool_size +#executor_thread_pool_size = 64 + +# Seconds to wait for a response from a call. (integer value) +#rpc_response_timeout = 60 + +# A URL representing the messaging driver to use and its full +# configuration. (string value) +#transport_url = + +# DEPRECATED: The messaging driver to use, defaults to rabbit. Other +# drivers include amqp and zmq. (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#rpc_backend = rabbit + +# The default exchange under which topics are scoped. May be +# overridden by an exchange name specified in the transport_url +# option. (string value) +#control_exchange = openstack + + +[cinder] + +# +# From manila +# + +# Allow attaching between instances and volumes in different +# availability zones. (boolean value) +# Deprecated group/name - [DEFAULT]/cinder_cross_az_attach +#cross_az_attach = true + +# Location of CA certificates file to use for cinder client requests. +# (string value) +# Deprecated group/name - [DEFAULT]/cinder_ca_certificates_file +#ca_certificates_file = + +# Number of cinderclient retries on failed HTTP calls. (integer value) +# Deprecated group/name - [DEFAULT]/cinder_http_retries +#http_retries = 3 + +# Allow to perform insecure SSL requests to cinder. (boolean value) +# Deprecated group/name - [DEFAULT]/cinder_api_insecure +#api_insecure = false + +# Endpoint type to be used with cinder client calls. (string value) +#endpoint_type = publicURL + +# Region name for connecting to cinder. (string value) +#region_name = + +# Authentication URL (string value) +#auth_url = + +# Authentication type to load (string value) +# Deprecated group/name - [cinder]/auth_plugin +#auth_type = + +# PEM encoded Certificate Authority to use when verifying HTTPs +# connections. (string value) +#cafile = + +# PEM encoded client certificate cert file (string value) +#certfile = + +# Optional domain ID to use with v3 and v2 parameters. It will be used +# for both the user and project domain in v3 and ignored in v2 +# authentication. (string value) +#default_domain_id = + +# Optional domain name to use with v3 API and v2 parameters. It will +# be used for both the user and project domain in v3 and ignored in v2 +# authentication. (string value) +#default_domain_name = + +# Domain ID to scope to (string value) +#domain_id = + +# Domain name to scope to (string value) +#domain_name = + +# Verify HTTPS connections. (boolean value) +#insecure = false + +# PEM encoded client certificate key file (string value) +#keyfile = + +# User's password (string value) +#password = + +# Domain ID containing project (string value) +#project_domain_id = + +# Domain name containing project (string value) +#project_domain_name = + +# Project ID to scope to (string value) +# Deprecated group/name - [cinder]/tenant_id +#project_id = + +# Project name to scope to (string value) +# Deprecated group/name - [cinder]/tenant_name +#project_name = + +# Timeout value for http requests (integer value) +#timeout = + +# Trust ID (string value) +#trust_id = + +# User's domain id (string value) +#user_domain_id = + +# User's domain name (string value) +#user_domain_name = + +# User id (string value) +#user_id = + +# Username (string value) +# Deprecated group/name - [cinder]/user_name +#username = + + +[cors] + +# +# From manila +# + +# Indicate whether this resource may be shared with the domain +# received in the requests "origin" header. Format: +# "://[:]", no trailing slash. Example: +# https://horizon.example.com (list value) +#allowed_origin = + +# Indicate that the actual request can include user credentials +# (boolean value) +#allow_credentials = true + +# Indicate which headers are safe to expose to the API. Defaults to +# HTTP Simple Headers. (list value) +#expose_headers = + +# Maximum cache age of CORS preflight requests. (integer value) +#max_age = 3600 + +# Indicate which methods can be used during the actual request. (list +# value) +#allow_methods = OPTIONS,GET,HEAD,POST,PUT,DELETE,TRACE,PATCH + +# Indicate which header field names may be used during the actual +# request. (list value) +#allow_headers = + +# +# From oslo.middleware.cors +# + +# Indicate whether this resource may be shared with the domain +# received in the requests "origin" header. Format: +# "://[:]", no trailing slash. Example: +# https://horizon.example.com (list value) +#allowed_origin = + +# Indicate that the actual request can include user credentials +# (boolean value) +#allow_credentials = true + +# Indicate which headers are safe to expose to the API. Defaults to +# HTTP Simple Headers. (list value) +#expose_headers = X-Auth-Token,X-OpenStack-Request-ID,X-Openstack-Manila-Api-Version,X-OpenStack-Manila-API-Experimental,X-Subject-Token,X-Service-Token + +# Maximum cache age of CORS preflight requests. (integer value) +#max_age = 3600 + +# Indicate which methods can be used during the actual request. (list +# value) +#allow_methods = GET,PUT,POST,DELETE,PATCH + +# Indicate which header field names may be used during the actual +# request. (list value) +#allow_headers = X-Auth-Token,X-OpenStack-Request-ID,X-Openstack-Manila-Api-Version,X-OpenStack-Manila-API-Experimental,X-Identity-Status,X-Roles,X-Service-Catalog,X-User-Id,X-Tenant-Id + + +[database] + +# +# From oslo.db +# + +# If True, SQLite uses synchronous mode. (boolean value) +#sqlite_synchronous = true + +# The back end to use for the database. (string value) +# Deprecated group/name - [DEFAULT]/db_backend +#backend = sqlalchemy + +# The SQLAlchemy connection string to use to connect to the database. +# (string value) +# Deprecated group/name - [DEFAULT]/sql_connection +# Deprecated group/name - [DATABASE]/sql_connection +# Deprecated group/name - [sql]/connection +#connection = + +# The SQLAlchemy connection string to use to connect to the slave +# database. (string value) +#slave_connection = + +# The SQL mode to be used for MySQL sessions. This option, including +# the default, overrides any server-set SQL mode. To use whatever SQL +# mode is set by the server configuration, set this to no value. +# Example: mysql_sql_mode= (string value) +#mysql_sql_mode = TRADITIONAL + +# If True, transparently enables support for handling MySQL Cluster +# (NDB). (boolean value) +#mysql_enable_ndb = false + +# Timeout before idle SQL connections are reaped. (integer value) +# Deprecated group/name - [DEFAULT]/sql_idle_timeout +# Deprecated group/name - [DATABASE]/sql_idle_timeout +# Deprecated group/name - [sql]/idle_timeout +#idle_timeout = 3600 + +# Minimum number of SQL connections to keep open in a pool. (integer +# value) +# Deprecated group/name - [DEFAULT]/sql_min_pool_size +# Deprecated group/name - [DATABASE]/sql_min_pool_size +#min_pool_size = 1 + +# Maximum number of SQL connections to keep open in a pool. Setting a +# value of 0 indicates no limit. (integer value) +# Deprecated group/name - [DEFAULT]/sql_max_pool_size +# Deprecated group/name - [DATABASE]/sql_max_pool_size +#max_pool_size = 5 + +# Maximum number of database connection retries during startup. Set to +# -1 to specify an infinite retry count. (integer value) +# Deprecated group/name - [DEFAULT]/sql_max_retries +# Deprecated group/name - [DATABASE]/sql_max_retries +#max_retries = 10 + +# Interval between retries of opening a SQL connection. (integer +# value) +# Deprecated group/name - [DEFAULT]/sql_retry_interval +# Deprecated group/name - [DATABASE]/reconnect_interval +#retry_interval = 10 + +# If set, use this value for max_overflow with SQLAlchemy. (integer +# value) +# Deprecated group/name - [DEFAULT]/sql_max_overflow +# Deprecated group/name - [DATABASE]/sqlalchemy_max_overflow +#max_overflow = 50 + +# Verbosity of SQL debugging information: 0=None, 100=Everything. +# (integer value) +# Minimum value: 0 +# Maximum value: 100 +# Deprecated group/name - [DEFAULT]/sql_connection_debug +#connection_debug = 0 + +# Add Python stack traces to SQL as comment strings. (boolean value) +# Deprecated group/name - [DEFAULT]/sql_connection_trace +#connection_trace = false + +# If set, use this value for pool_timeout with SQLAlchemy. (integer +# value) +# Deprecated group/name - [DATABASE]/sqlalchemy_pool_timeout +#pool_timeout = + +# Enable the experimental use of database reconnect on connection +# lost. (boolean value) +#use_db_reconnect = false + +# Seconds between retries of a database transaction. (integer value) +#db_retry_interval = 1 + +# If True, increases the interval between retries of a database +# operation up to db_max_retry_interval. (boolean value) +#db_inc_retry_interval = true + +# If db_inc_retry_interval is set, the maximum seconds between retries +# of a database operation. (integer value) +#db_max_retry_interval = 10 + +# Maximum retries in case of connection error or deadlock error before +# error is raised. Set to -1 to specify an infinite retry count. +# (integer value) +#db_max_retries = 20 + +# +# From oslo.db.concurrency +# + +# Enable the experimental use of thread pooling for all DB API calls +# (boolean value) +# Deprecated group/name - [DEFAULT]/dbapi_use_tpool +#use_tpool = false + + +[healthcheck] + +# +# From manila +# + +# DEPRECATED: The path to respond to healtcheck requests on. (string +# value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +#path = /healthcheck + +# Show more detailed information as part of the response (boolean +# value) +#detailed = false + +# Additional backends that can perform health checks and report that +# information back as part of a request. (list value) +#backends = + +# Check the presence of a file to determine if an application is +# running on a port. Used by DisableByFileHealthcheck plugin. (string +# value) +#disable_by_file_path = + +# Check the presence of a file based on a port to determine if an +# application is running on a port. Expects a "port:path" list of +# strings. Used by DisableByFilesPortsHealthcheck plugin. (list value) +#disable_by_file_paths = + + +[keystone_authtoken] + +# +# From keystonemiddleware.auth_token +# + +# Complete "public" Identity API endpoint. This endpoint should not be +# an "admin" endpoint, as it should be accessible by all end users. +# Unauthenticated clients are redirected to this endpoint to +# authenticate. Although this endpoint should ideally be unversioned, +# client support in the wild varies. If you're using a versioned v2 +# endpoint here, then this should *not* be the same endpoint the +# service user utilizes for validating tokens, because normal end +# users may not be able to reach that endpoint. (string value) +#auth_uri = + +# API version of the admin Identity API endpoint. (string value) +#auth_version = + +# Do not handle authorization requests within the middleware, but +# delegate the authorization decision to downstream WSGI components. +# (boolean value) +#delay_auth_decision = false + +# Request timeout value for communicating with Identity API server. +# (integer value) +#http_connect_timeout = + +# How many times are we trying to reconnect when communicating with +# Identity API Server. (integer value) +#http_request_max_retries = 3 + +# Request environment key where the Swift cache object is stored. When +# auth_token middleware is deployed with a Swift cache, use this +# option to have the middleware share a caching backend with swift. +# Otherwise, use the ``memcached_servers`` option instead. (string +# value) +#cache = + +# Required if identity server requires client certificate (string +# value) +#certfile = + +# Required if identity server requires client certificate (string +# value) +#keyfile = + +# A PEM encoded Certificate Authority to use when verifying HTTPs +# connections. Defaults to system CAs. (string value) +#cafile = + +# Verify HTTPS connections. (boolean value) +#insecure = false + +# The region in which the identity server can be found. (string value) +#region_name = + +# DEPRECATED: Directory used to cache files related to PKI tokens. +# This option has been deprecated in the Ocata release and will be +# removed in the P release. (string value) +# This option is deprecated for removal since Ocata. +# Its value may be silently ignored in the future. +# Reason: PKI token format is no longer supported. +#signing_dir = + +# Optionally specify a list of memcached server(s) to use for caching. +# If left undefined, tokens will instead be cached in-process. (list +# value) +# Deprecated group/name - [keystone_authtoken]/memcache_servers +#memcached_servers = + +# In order to prevent excessive effort spent validating tokens, the +# middleware caches previously-seen tokens for a configurable duration +# (in seconds). Set to -1 to disable caching completely. (integer +# value) +#token_cache_time = 300 + +# DEPRECATED: Determines the frequency at which the list of revoked +# tokens is retrieved from the Identity service (in seconds). A high +# number of revocation events combined with a low cache duration may +# significantly reduce performance. Only valid for PKI tokens. This +# option has been deprecated in the Ocata release and will be removed +# in the P release. (integer value) +# This option is deprecated for removal since Ocata. +# Its value may be silently ignored in the future. +# Reason: PKI token format is no longer supported. +#revocation_cache_time = 10 + +# (Optional) If defined, indicate whether token data should be +# authenticated or authenticated and encrypted. If MAC, token data is +# authenticated (with HMAC) in the cache. If ENCRYPT, token data is +# encrypted and authenticated in the cache. If the value is not one of +# these options or empty, auth_token will raise an exception on +# initialization. (string value) +# Allowed values: None, MAC, ENCRYPT +#memcache_security_strategy = None + +# (Optional, mandatory if memcache_security_strategy is defined) This +# string is used for key derivation. (string value) +#memcache_secret_key = + +# (Optional) Number of seconds memcached server is considered dead +# before it is tried again. (integer value) +#memcache_pool_dead_retry = 300 + +# (Optional) Maximum total number of open connections to every +# memcached server. (integer value) +#memcache_pool_maxsize = 10 + +# (Optional) Socket timeout in seconds for communicating with a +# memcached server. (integer value) +#memcache_pool_socket_timeout = 3 + +# (Optional) Number of seconds a connection to memcached is held +# unused in the pool before it is closed. (integer value) +#memcache_pool_unused_timeout = 60 + +# (Optional) Number of seconds that an operation will wait to get a +# memcached client connection from the pool. (integer value) +#memcache_pool_conn_get_timeout = 10 + +# (Optional) Use the advanced (eventlet safe) memcached client pool. +# The advanced pool will only work under python 2.x. (boolean value) +#memcache_use_advanced_pool = false + +# (Optional) Indicate whether to set the X-Service-Catalog header. If +# False, middleware will not ask for service catalog on token +# validation and will not set the X-Service-Catalog header. (boolean +# value) +#include_service_catalog = true + +# Used to control the use and type of token binding. Can be set to: +# "disabled" to not check token binding. "permissive" (default) to +# validate binding information if the bind type is of a form known to +# the server and ignore it if not. "strict" like "permissive" but if +# the bind type is unknown the token will be rejected. "required" any +# form of token binding is needed to be allowed. Finally the name of a +# binding method that must be present in tokens. (string value) +#enforce_token_bind = permissive + +# DEPRECATED: If true, the revocation list will be checked for cached +# tokens. This requires that PKI tokens are configured on the identity +# server. (boolean value) +# This option is deprecated for removal since Ocata. +# Its value may be silently ignored in the future. +# Reason: PKI token format is no longer supported. +#check_revocations_for_cached = false + +# DEPRECATED: Hash algorithms to use for hashing PKI tokens. This may +# be a single algorithm or multiple. The algorithms are those +# supported by Python standard hashlib.new(). The hashes will be tried +# in the order given, so put the preferred one first for performance. +# The result of the first hash will be stored in the cache. This will +# typically be set to multiple values only while migrating from a less +# secure algorithm to a more secure one. Once all the old tokens are +# expired this option should be set to a single value for better +# performance. (list value) +# This option is deprecated for removal since Ocata. +# Its value may be silently ignored in the future. +# Reason: PKI token format is no longer supported. +#hash_algorithms = md5 + +# A choice of roles that must be present in a service token. Service +# tokens are allowed to request that an expired token can be used and +# so this check should tightly control that only actual services +# should be sending this token. Roles here are applied as an ANY check +# so any role in this list must be present. For backwards +# compatibility reasons this currently only affects the allow_expired +# check. (list value) +#service_token_roles = service + +# For backwards compatibility reasons we must let valid service tokens +# pass that don't pass the service_token_roles check as valid. Setting +# this true will become the default in a future release and should be +# enabled if possible. (boolean value) +#service_token_roles_required = false + +# Authentication type to load (string value) +# Deprecated group/name - [keystone_authtoken]/auth_plugin +#auth_type = + +# Config Section from which to load plugin specific options (string +# value) +#auth_section = + + +[matchmaker_redis] + +# +# From oslo.messaging +# + +# DEPRECATED: Host to locate redis. (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#host = 127.0.0.1 + +# DEPRECATED: Use this port to connect to redis host. (port value) +# Minimum value: 0 +# Maximum value: 65535 +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#port = 6379 + +# DEPRECATED: Password for Redis server (optional). (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#password = + +# DEPRECATED: List of Redis Sentinel hosts (fault tolerance mode), +# e.g., [host:port, host1:port ... ] (list value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#sentinel_hosts = + +# Redis replica set name. (string value) +#sentinel_group_name = oslo-messaging-zeromq + +# Time in ms to wait between connection attempts. (integer value) +#wait_timeout = 2000 + +# Time in ms to wait before the transaction is killed. (integer value) +#check_timeout = 20000 + +# Timeout in ms on blocking socket operations. (integer value) +#socket_timeout = 10000 + + +[neutron] + +# +# From manila +# + +# URL for connecting to neutron. (string value) +# Deprecated group/name - [DEFAULT]/neutron_url +#url = http://127.0.0.1:9696 + +# Timeout value for connecting to neutron in seconds. (integer value) +# Deprecated group/name - [DEFAULT]/neutron_url_timeout +#url_timeout = 30 + +# If set, ignore any SSL validation issues. (boolean value) +#api_insecure = false + +# Auth strategy for connecting to neutron in admin context. (string +# value) +#auth_strategy = keystone + +# DEPRECATED: Location of CA certificates file to use for neutron +# client requests. (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +#ca_certificates_file = + +# Endpoint type to be used with neutron client calls. (string value) +#endpoint_type = publicURL + +# Region name for connecting to neutron in admin context. (string +# value) +#region_name = + +# Authentication URL (string value) +#auth_url = + +# Authentication type to load (string value) +# Deprecated group/name - [neutron]/auth_plugin +#auth_type = + +# PEM encoded Certificate Authority to use when verifying HTTPs +# connections. (string value) +#cafile = + +# PEM encoded client certificate cert file (string value) +#certfile = + +# Optional domain ID to use with v3 and v2 parameters. It will be used +# for both the user and project domain in v3 and ignored in v2 +# authentication. (string value) +#default_domain_id = + +# Optional domain name to use with v3 API and v2 parameters. It will +# be used for both the user and project domain in v3 and ignored in v2 +# authentication. (string value) +#default_domain_name = + +# Domain ID to scope to (string value) +#domain_id = + +# Domain name to scope to (string value) +#domain_name = + +# Verify HTTPS connections. (boolean value) +#insecure = false + +# PEM encoded client certificate key file (string value) +#keyfile = + +# User's password (string value) +#password = + +# Domain ID containing project (string value) +#project_domain_id = + +# Domain name containing project (string value) +#project_domain_name = + +# Project ID to scope to (string value) +# Deprecated group/name - [neutron]/tenant_id +#project_id = + +# Project name to scope to (string value) +# Deprecated group/name - [neutron]/tenant_name +#project_name = + +# Timeout value for http requests (integer value) +#timeout = + +# Trust ID (string value) +#trust_id = + +# User's domain id (string value) +#user_domain_id = + +# User's domain name (string value) +#user_domain_name = + +# User id (string value) +#user_id = + +# Username (string value) +# Deprecated group/name - [neutron]/user_name +#username = + + +[nova] + +# +# From manila +# + +# Version of Nova API to be used. (string value) +# Deprecated group/name - [DEFAULT]/nova_api_microversion +#api_microversion = 2.10 + +# Location of CA certificates file to use for nova client requests. +# (string value) +# Deprecated group/name - [DEFAULT]/nova_ca_certificates_file +#ca_certificates_file = + +# Allow to perform insecure SSL requests to nova. (boolean value) +# Deprecated group/name - [DEFAULT]/nova_api_insecure +#api_insecure = false + +# Endpoint type to be used with nova client calls. (string value) +#endpoint_type = publicURL + +# Region name for connecting to nova. (string value) +#region_name = + +# Authentication URL (string value) +#auth_url = + +# Authentication type to load (string value) +# Deprecated group/name - [nova]/auth_plugin +#auth_type = + +# PEM encoded Certificate Authority to use when verifying HTTPs +# connections. (string value) +#cafile = + +# PEM encoded client certificate cert file (string value) +#certfile = + +# Optional domain ID to use with v3 and v2 parameters. It will be used +# for both the user and project domain in v3 and ignored in v2 +# authentication. (string value) +#default_domain_id = + +# Optional domain name to use with v3 API and v2 parameters. It will +# be used for both the user and project domain in v3 and ignored in v2 +# authentication. (string value) +#default_domain_name = + +# Domain ID to scope to (string value) +#domain_id = + +# Domain name to scope to (string value) +#domain_name = + +# Verify HTTPS connections. (boolean value) +#insecure = false + +# PEM encoded client certificate key file (string value) +#keyfile = + +# User's password (string value) +#password = + +# Domain ID containing project (string value) +#project_domain_id = + +# Domain name containing project (string value) +#project_domain_name = + +# Project ID to scope to (string value) +# Deprecated group/name - [nova]/tenant_id +#project_id = + +# Project name to scope to (string value) +# Deprecated group/name - [nova]/tenant_name +#project_name = + +# Timeout value for http requests (integer value) +#timeout = + +# Trust ID (string value) +#trust_id = + +# User's domain id (string value) +#user_domain_id = + +# User's domain name (string value) +#user_domain_name = + +# User id (string value) +#user_id = + +# Username (string value) +# Deprecated group/name - [nova]/user_name +#username = + + +[oslo_concurrency] + +# +# From manila +# + +# Enables or disables inter-process locks. (boolean value) +#disable_process_locking = false + +# Directory to use for lock files. For security, the specified +# directory should only be writable by the user running the processes +# that need locking. Defaults to environment variable OSLO_LOCK_PATH. +# If external locks are used, a lock path must be set. (string value) +#lock_path = + + +[oslo_messaging_amqp] + +# +# From oslo.messaging +# + +# Name for the AMQP container. must be globally unique. Defaults to a +# generated UUID (string value) +#container_name = + +# Timeout for inactive connections (in seconds) (integer value) +#idle_timeout = 0 + +# Debug: dump AMQP frames to stdout (boolean value) +#trace = false + +# Attempt to connect via SSL. If no other ssl-related parameters are +# given, it will use the system's CA-bundle to verify the server's +# certificate. (boolean value) +#ssl = false + +# CA certificate PEM file used to verify the server's certificate +# (string value) +#ssl_ca_file = + +# Self-identifying certificate PEM file for client authentication +# (string value) +#ssl_cert_file = + +# Private key PEM file used to sign ssl_cert_file certificate +# (optional) (string value) +#ssl_key_file = + +# Password for decrypting ssl_key_file (if encrypted) (string value) +#ssl_key_password = + +# DEPRECATED: Accept clients using either SSL or plain TCP (boolean +# value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Not applicable - not a SSL server +#allow_insecure_clients = false + +# Space separated list of acceptable SASL mechanisms (string value) +#sasl_mechanisms = + +# Path to directory that contains the SASL configuration (string +# value) +#sasl_config_dir = + +# Name of configuration file (without .conf suffix) (string value) +#sasl_config_name = + +# SASL realm to use if no realm present in username (string value) +#sasl_default_realm = + +# DEPRECATED: User name for message broker authentication (string +# value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Should use configuration option transport_url to provide the +# username. +#username = + +# DEPRECATED: Password for message broker authentication (string +# value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Should use configuration option transport_url to provide the +# password. +#password = + +# Seconds to pause before attempting to re-connect. (integer value) +# Minimum value: 1 +#connection_retry_interval = 1 + +# Increase the connection_retry_interval by this many seconds after +# each unsuccessful failover attempt. (integer value) +# Minimum value: 0 +#connection_retry_backoff = 2 + +# Maximum limit for connection_retry_interval + +# connection_retry_backoff (integer value) +# Minimum value: 1 +#connection_retry_interval_max = 30 + +# Time to pause between re-connecting an AMQP 1.0 link that failed due +# to a recoverable error. (integer value) +# Minimum value: 1 +#link_retry_delay = 10 + +# The maximum number of attempts to re-send a reply message which +# failed due to a recoverable error. (integer value) +# Minimum value: -1 +#default_reply_retry = 0 + +# The deadline for an rpc reply message delivery. (integer value) +# Minimum value: 5 +#default_reply_timeout = 30 + +# The deadline for an rpc cast or call message delivery. Only used +# when caller does not provide a timeout expiry. (integer value) +# Minimum value: 5 +#default_send_timeout = 30 + +# The deadline for a sent notification message delivery. Only used +# when caller does not provide a timeout expiry. (integer value) +# Minimum value: 5 +#default_notify_timeout = 30 + +# The duration to schedule a purge of idle sender links. Detach link +# after expiry. (integer value) +# Minimum value: 1 +#default_sender_link_timeout = 600 + +# Indicates the addressing mode used by the driver. +# Permitted values: +# 'legacy' - use legacy non-routable addressing +# 'routable' - use routable addresses +# 'dynamic' - use legacy addresses if the message bus does not +# support routing otherwise use routable addressing (string value) +#addressing_mode = dynamic + +# address prefix used when sending to a specific server (string value) +#server_request_prefix = exclusive + +# address prefix used when broadcasting to all servers (string value) +#broadcast_prefix = broadcast + +# address prefix when sending to any server in group (string value) +#group_request_prefix = unicast + +# Address prefix for all generated RPC addresses (string value) +#rpc_address_prefix = openstack.org/om/rpc + +# Address prefix for all generated Notification addresses (string +# value) +#notify_address_prefix = openstack.org/om/notify + +# Appended to the address prefix when sending a fanout message. Used +# by the message bus to identify fanout messages. (string value) +#multicast_address = multicast + +# Appended to the address prefix when sending to a particular +# RPC/Notification server. Used by the message bus to identify +# messages sent to a single destination. (string value) +#unicast_address = unicast + +# Appended to the address prefix when sending to a group of consumers. +# Used by the message bus to identify messages that should be +# delivered in a round-robin fashion across consumers. (string value) +#anycast_address = anycast + +# Exchange name used in notification addresses. +# Exchange name resolution precedence: +# Target.exchange if set +# else default_notification_exchange if set +# else control_exchange if set +# else 'notify' (string value) +#default_notification_exchange = + +# Exchange name used in RPC addresses. +# Exchange name resolution precedence: +# Target.exchange if set +# else default_rpc_exchange if set +# else control_exchange if set +# else 'rpc' (string value) +#default_rpc_exchange = + +# Window size for incoming RPC Reply messages. (integer value) +# Minimum value: 1 +#reply_link_credit = 200 + +# Window size for incoming RPC Request messages (integer value) +# Minimum value: 1 +#rpc_server_credit = 100 + +# Window size for incoming Notification messages (integer value) +# Minimum value: 1 +#notify_server_credit = 100 + +# Send messages of this type pre-settled. +# Pre-settled messages will not receive acknowledgement +# from the peer. Note well: pre-settled messages may be +# silently discarded if the delivery fails. +# Permitted values: +# 'rpc-call' - send RPC Calls pre-settled +# 'rpc-reply'- send RPC Replies pre-settled +# 'rpc-cast' - Send RPC Casts pre-settled +# 'notify' - Send Notifications pre-settled +# (multi valued) +#pre_settled = rpc-cast +#pre_settled = rpc-reply + + +[oslo_messaging_kafka] + +# +# From oslo.messaging +# + +# DEPRECATED: Default Kafka broker Host (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#kafka_default_host = localhost + +# DEPRECATED: Default Kafka broker Port (port value) +# Minimum value: 0 +# Maximum value: 65535 +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#kafka_default_port = 9092 + +# Max fetch bytes of Kafka consumer (integer value) +#kafka_max_fetch_bytes = 1048576 + +# Default timeout(s) for Kafka consumers (floating point value) +#kafka_consumer_timeout = 1.0 + +# Pool Size for Kafka Consumers (integer value) +#pool_size = 10 + +# The pool size limit for connections expiration policy (integer +# value) +#conn_pool_min_size = 2 + +# The time-to-live in sec of idle connections in the pool (integer +# value) +#conn_pool_ttl = 1200 + +# Group id for Kafka consumer. Consumers in one group will coordinate +# message consumption (string value) +#consumer_group = oslo_messaging_consumer + +# Upper bound on the delay for KafkaProducer batching in seconds +# (floating point value) +#producer_batch_timeout = 0.0 + +# Size of batch for the producer async send (integer value) +#producer_batch_size = 16384 + + +[oslo_messaging_notifications] + +# +# From oslo.messaging +# + +# The Drivers(s) to handle sending notifications. Possible values are +# messaging, messagingv2, routing, log, test, noop (multi valued) +# Deprecated group/name - [DEFAULT]/notification_driver +#driver = + +# A URL representing the messaging driver to use for notifications. If +# not set, we fall back to the same configuration used for RPC. +# (string value) +# Deprecated group/name - [DEFAULT]/notification_transport_url +#transport_url = + +# AMQP topic used for OpenStack notifications. (list value) +# Deprecated group/name - [rpc_notifier2]/topics +# Deprecated group/name - [DEFAULT]/notification_topics +#topics = notifications + +# The maximum number of attempts to re-send a notification message +# which failed to be delivered due to a recoverable error. 0 - No +# retry, -1 - indefinite (integer value) +#retry = -1 + + +[oslo_messaging_rabbit] + +# +# From oslo.messaging +# + +# Use durable queues in AMQP. (boolean value) +# Deprecated group/name - [DEFAULT]/amqp_durable_queues +# Deprecated group/name - [DEFAULT]/rabbit_durable_queues +#amqp_durable_queues = false + +# Auto-delete queues in AMQP. (boolean value) +#amqp_auto_delete = false + +# Enable SSL (boolean value) +#ssl = + +# SSL version to use (valid only if SSL enabled). Valid values are +# TLSv1 and SSLv23. SSLv2, SSLv3, TLSv1_1, and TLSv1_2 may be +# available on some distributions. (string value) +# Deprecated group/name - [oslo_messaging_rabbit]/kombu_ssl_version +#ssl_version = + +# SSL key file (valid only if SSL enabled). (string value) +# Deprecated group/name - [oslo_messaging_rabbit]/kombu_ssl_keyfile +#ssl_key_file = + +# SSL cert file (valid only if SSL enabled). (string value) +# Deprecated group/name - [oslo_messaging_rabbit]/kombu_ssl_certfile +#ssl_cert_file = + +# SSL certification authority file (valid only if SSL enabled). +# (string value) +# Deprecated group/name - [oslo_messaging_rabbit]/kombu_ssl_ca_certs +#ssl_ca_file = + +# How long to wait before reconnecting in response to an AMQP consumer +# cancel notification. (floating point value) +#kombu_reconnect_delay = 1.0 + +# EXPERIMENTAL: Possible values are: gzip, bz2. If not set compression +# will not be used. This option may not be available in future +# versions. (string value) +#kombu_compression = + +# How long to wait a missing client before abandoning to send it its +# replies. This value should not be longer than rpc_response_timeout. +# (integer value) +# Deprecated group/name - [oslo_messaging_rabbit]/kombu_reconnect_timeout +#kombu_missing_consumer_retry_timeout = 60 + +# Determines how the next RabbitMQ node is chosen in case the one we +# are currently connected to becomes unavailable. Takes effect only if +# more than one RabbitMQ node is provided in config. (string value) +# Allowed values: round-robin, shuffle +#kombu_failover_strategy = round-robin + +# DEPRECATED: The RabbitMQ broker address where a single node is used. +# (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#rabbit_host = localhost + +# DEPRECATED: The RabbitMQ broker port where a single node is used. +# (port value) +# Minimum value: 0 +# Maximum value: 65535 +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#rabbit_port = 5672 + +# DEPRECATED: RabbitMQ HA cluster host:port pairs. (list value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#rabbit_hosts = $rabbit_host:$rabbit_port + +# DEPRECATED: The RabbitMQ userid. (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#rabbit_userid = guest + +# DEPRECATED: The RabbitMQ password. (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#rabbit_password = guest + +# The RabbitMQ login method. (string value) +# Allowed values: PLAIN, AMQPLAIN, RABBIT-CR-DEMO +#rabbit_login_method = AMQPLAIN + +# DEPRECATED: The RabbitMQ virtual host. (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +# Reason: Replaced by [DEFAULT]/transport_url +#rabbit_virtual_host = / + +# How frequently to retry connecting with RabbitMQ. (integer value) +#rabbit_retry_interval = 1 + +# How long to backoff for between retries when connecting to RabbitMQ. +# (integer value) +#rabbit_retry_backoff = 2 + +# Maximum interval of RabbitMQ connection retries. Default is 30 +# seconds. (integer value) +#rabbit_interval_max = 30 + +# DEPRECATED: Maximum number of RabbitMQ connection retries. Default +# is 0 (infinite retry count). (integer value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +#rabbit_max_retries = 0 + +# Try to use HA queues in RabbitMQ (x-ha-policy: all). If you change +# this option, you must wipe the RabbitMQ database. In RabbitMQ 3.0, +# queue mirroring is no longer controlled by the x-ha-policy argument +# when declaring a queue. If you just want to make sure that all +# queues (except those with auto-generated names) are mirrored across +# all nodes, run: "rabbitmqctl set_policy HA '^(?!amq\.).*' '{"ha- +# mode": "all"}' " (boolean value) +#rabbit_ha_queues = false + +# Positive integer representing duration in seconds for queue TTL +# (x-expires). Queues which are unused for the duration of the TTL are +# automatically deleted. The parameter affects only reply and fanout +# queues. (integer value) +# Minimum value: 1 +#rabbit_transient_queues_ttl = 1800 + +# Specifies the number of messages to prefetch. Setting to zero allows +# unlimited messages. (integer value) +#rabbit_qos_prefetch_count = 0 + +# Number of seconds after which the Rabbit broker is considered down +# if heartbeat's keep-alive fails (0 disable the heartbeat). +# EXPERIMENTAL (integer value) +#heartbeat_timeout_threshold = 60 + +# How often times during the heartbeat_timeout_threshold we check the +# heartbeat. (integer value) +#heartbeat_rate = 2 + +# Deprecated, use rpc_backend=kombu+memory or rpc_backend=fake +# (boolean value) +#fake_rabbit = false + +# Maximum number of channels to allow (integer value) +#channel_max = + +# The maximum byte size for an AMQP frame (integer value) +#frame_max = + +# How often to send heartbeats for consumer's connections (integer +# value) +#heartbeat_interval = 3 + +# Arguments passed to ssl.wrap_socket (dict value) +#ssl_options = + +# Set socket timeout in seconds for connection's socket (floating +# point value) +#socket_timeout = 0.25 + +# Set TCP_USER_TIMEOUT in seconds for connection's socket (floating +# point value) +#tcp_user_timeout = 0.25 + +# Set delay for reconnection to some host which has connection error +# (floating point value) +#host_connection_reconnect_delay = 0.25 + +# Connection factory implementation (string value) +# Allowed values: new, single, read_write +#connection_factory = single + +# Maximum number of connections to keep queued. (integer value) +#pool_max_size = 30 + +# Maximum number of connections to create above `pool_max_size`. +# (integer value) +#pool_max_overflow = 0 + +# Default number of seconds to wait for a connections to available +# (integer value) +#pool_timeout = 30 + +# Lifetime of a connection (since creation) in seconds or None for no +# recycling. Expired connections are closed on acquire. (integer +# value) +#pool_recycle = 600 + +# Threshold at which inactive (since release) connections are +# considered stale in seconds or None for no staleness. Stale +# connections are closed on acquire. (integer value) +#pool_stale = 60 + +# Default serialization mechanism for serializing/deserializing +# outgoing/incoming messages (string value) +# Allowed values: json, msgpack +#default_serializer_type = json + +# Persist notification messages. (boolean value) +#notification_persistence = false + +# Exchange name for sending notifications (string value) +#default_notification_exchange = ${control_exchange}_notification + +# Max number of not acknowledged message which RabbitMQ can send to +# notification listener. (integer value) +#notification_listener_prefetch_count = 100 + +# Reconnecting retry count in case of connectivity problem during +# sending notification, -1 means infinite retry. (integer value) +#default_notification_retry_attempts = -1 + +# Reconnecting retry delay in case of connectivity problem during +# sending notification message (floating point value) +#notification_retry_delay = 0.25 + +# Time to live for rpc queues without consumers in seconds. (integer +# value) +#rpc_queue_expiration = 60 + +# Exchange name for sending RPC messages (string value) +#default_rpc_exchange = ${control_exchange}_rpc + +# Exchange name for receiving RPC replies (string value) +#rpc_reply_exchange = ${control_exchange}_rpc_reply + +# Max number of not acknowledged message which RabbitMQ can send to +# rpc listener. (integer value) +#rpc_listener_prefetch_count = 100 + +# Max number of not acknowledged message which RabbitMQ can send to +# rpc reply listener. (integer value) +#rpc_reply_listener_prefetch_count = 100 + +# Reconnecting retry count in case of connectivity problem during +# sending reply. -1 means infinite retry during rpc_timeout (integer +# value) +#rpc_reply_retry_attempts = -1 + +# Reconnecting retry delay in case of connectivity problem during +# sending reply. (floating point value) +#rpc_reply_retry_delay = 0.25 + +# Reconnecting retry count in case of connectivity problem during +# sending RPC message, -1 means infinite retry. If actual retry +# attempts in not 0 the rpc request could be processed more than one +# time (integer value) +#default_rpc_retry_attempts = -1 + +# Reconnecting retry delay in case of connectivity problem during +# sending RPC message (floating point value) +#rpc_retry_delay = 0.25 + + +[oslo_messaging_zmq] + +# +# From oslo.messaging +# + +# ZeroMQ bind address. Should be a wildcard (*), an ethernet +# interface, or IP. The "host" option should point or resolve to this +# address. (string value) +#rpc_zmq_bind_address = * + +# MatchMaker driver. (string value) +# Allowed values: redis, sentinel, dummy +#rpc_zmq_matchmaker = redis + +# Number of ZeroMQ contexts, defaults to 1. (integer value) +#rpc_zmq_contexts = 1 + +# Maximum number of ingress messages to locally buffer per topic. +# Default is unlimited. (integer value) +#rpc_zmq_topic_backlog = + +# Directory for holding IPC sockets. (string value) +#rpc_zmq_ipc_dir = /var/run/openstack + +# Name of this node. Must be a valid hostname, FQDN, or IP address. +# Must match "host" option, if running Nova. (string value) +#rpc_zmq_host = localhost + +# Number of seconds to wait before all pending messages will be sent +# after closing a socket. The default value of -1 specifies an +# infinite linger period. The value of 0 specifies no linger period. +# Pending messages shall be discarded immediately when the socket is +# closed. Positive values specify an upper bound for the linger +# period. (integer value) +# Deprecated group/name - [DEFAULT]/rpc_cast_timeout +#zmq_linger = -1 + +# The default number of seconds that poll should wait. Poll raises +# timeout exception when timeout expired. (integer value) +#rpc_poll_timeout = 1 + +# Expiration timeout in seconds of a name service record about +# existing target ( < 0 means no timeout). (integer value) +#zmq_target_expire = 300 + +# Update period in seconds of a name service record about existing +# target. (integer value) +#zmq_target_update = 180 + +# Use PUB/SUB pattern for fanout methods. PUB/SUB always uses proxy. +# (boolean value) +#use_pub_sub = false + +# Use ROUTER remote proxy. (boolean value) +#use_router_proxy = false + +# This option makes direct connections dynamic or static. It makes +# sense only with use_router_proxy=False which means to use direct +# connections for direct message types (ignored otherwise). (boolean +# value) +#use_dynamic_connections = false + +# How many additional connections to a host will be made for failover +# reasons. This option is actual only in dynamic connections mode. +# (integer value) +#zmq_failover_connections = 2 + +# Minimal port number for random ports range. (port value) +# Minimum value: 0 +# Maximum value: 65535 +#rpc_zmq_min_port = 49153 + +# Maximal port number for random ports range. (integer value) +# Minimum value: 1 +# Maximum value: 65536 +#rpc_zmq_max_port = 65536 + +# Number of retries to find free port number before fail with +# ZMQBindError. (integer value) +#rpc_zmq_bind_port_retries = 100 + +# Default serialization mechanism for serializing/deserializing +# outgoing/incoming messages (string value) +# Allowed values: json, msgpack +#rpc_zmq_serialization = json + +# This option configures round-robin mode in zmq socket. True means +# not keeping a queue when server side disconnects. False means to +# keep queue and messages even if server is disconnected, when the +# server appears we send all accumulated messages to it. (boolean +# value) +#zmq_immediate = true + +# Enable/disable TCP keepalive (KA) mechanism. The default value of -1 +# (or any other negative value) means to skip any overrides and leave +# it to OS default; 0 and 1 (or any other positive value) mean to +# disable and enable the option respectively. (integer value) +#zmq_tcp_keepalive = -1 + +# The duration between two keepalive transmissions in idle condition. +# The unit is platform dependent, for example, seconds in Linux, +# milliseconds in Windows etc. The default value of -1 (or any other +# negative value and 0) means to skip any overrides and leave it to OS +# default. (integer value) +#zmq_tcp_keepalive_idle = -1 + +# The number of retransmissions to be carried out before declaring +# that remote end is not available. The default value of -1 (or any +# other negative value and 0) means to skip any overrides and leave it +# to OS default. (integer value) +#zmq_tcp_keepalive_cnt = -1 + +# The duration between two successive keepalive retransmissions, if +# acknowledgement to the previous keepalive transmission is not +# received. The unit is platform dependent, for example, seconds in +# Linux, milliseconds in Windows etc. The default value of -1 (or any +# other negative value and 0) means to skip any overrides and leave it +# to OS default. (integer value) +#zmq_tcp_keepalive_intvl = -1 + +# Maximum number of (green) threads to work concurrently. (integer +# value) +#rpc_thread_pool_size = 100 + +# Expiration timeout in seconds of a sent/received message after which +# it is not tracked anymore by a client/server. (integer value) +#rpc_message_ttl = 300 + +# Wait for message acknowledgements from receivers. This mechanism +# works only via proxy without PUB/SUB. (boolean value) +#rpc_use_acks = false + +# Number of seconds to wait for an ack from a cast/call. After each +# retry attempt this timeout is multiplied by some specified +# multiplier. (integer value) +#rpc_ack_timeout_base = 15 + +# Number to multiply base ack timeout by after each retry attempt. +# (integer value) +#rpc_ack_timeout_multiplier = 2 + +# Default number of message sending attempts in case of any problems +# occurred: positive value N means at most N retries, 0 means no +# retries, None or -1 (or any other negative values) mean to retry +# forever. This option is used only if acknowledgments are enabled. +# (integer value) +#rpc_retry_attempts = 3 + +# List of publisher hosts SubConsumer can subscribe on. This option +# has higher priority then the default publishers list taken from the +# matchmaker. (list value) +#subscribe_on = + + +[oslo_middleware] + +# +# From manila +# + +# The maximum body size for each request, in bytes. (integer value) +# Deprecated group/name - [DEFAULT]/osapi_max_request_body_size +# Deprecated group/name - [DEFAULT]/max_request_body_size +#max_request_body_size = 114688 + +# DEPRECATED: The HTTP Header that will be used to determine what the +# original request protocol scheme was, even if it was hidden by a SSL +# termination proxy. (string value) +# This option is deprecated for removal. +# Its value may be silently ignored in the future. +#secure_proxy_ssl_header = X-Forwarded-Proto + +# Whether the application is behind a proxy or not. This determines if +# the middleware should parse the headers or not. (boolean value) +#enable_proxy_headers_parsing = false + +# +# From oslo.middleware.http_proxy_to_wsgi +# + +# Whether the application is behind a proxy or not. This determines if +# the middleware should parse the headers or not. (boolean value) +#enable_proxy_headers_parsing = false + + +[oslo_policy] + +# +# From manila +# + +# The file that defines policies. (string value) +#policy_file = policy.json + +# Default rule. Enforced when a requested rule is not found. (string +# value) +#policy_default_rule = default + +# Directories where policy configuration files are stored. They can be +# relative to any directory in the search path defined by the +# config_dir option, or absolute paths. The file defined by +# policy_file must exist for these directories to be searched. +# Missing or empty directories are ignored. (multi valued) +#policy_dirs = policy.d diff --git a/doc/source/conf.py b/doc/source/conf.py index dda88c0a34..19e61460d6 100644 --- a/doc/source/conf.py +++ b/doc/source/conf.py @@ -54,8 +54,13 @@ extensions = ['sphinx.ext.autodoc', 'sphinx.ext.ifconfig', 'sphinx.ext.graphviz', 'openstackdocstheme', + 'oslo_config.sphinxconfiggen', ] +config_generator_config_file = ( + '../../etc/oslo-config-generator/manila.conf') +sample_config_basename = '_static/manila' + # openstackdocstheme options repository_name = 'openstack/manila' bug_project = 'manila' diff --git a/doc/source/configuration/README.rst b/doc/source/configuration/README.rst deleted file mode 100644 index ebb11a1707..0000000000 --- a/doc/source/configuration/README.rst +++ /dev/null @@ -1,17 +0,0 @@ -================================== -Manila Configuration Documentation -================================== - -Introduction: -------------- - -This directory is intended to hold any documentation that relates to -how to configure Manila. Some of this content will be automatically -generated in upcoming documentation work. At the moment, however, it -is not. Changes to configuration options for Manila or its drivers -need to be put under this directory. - -The full spec for organization of documentation may be seen in the -`OS Manuals Migration Spec -`_. - diff --git a/doc/source/configuration/figures/hds_network.jpg b/doc/source/configuration/figures/hds_network.jpg new file mode 100644 index 0000000000000000000000000000000000000000..bfd9d2bb7c52231190d1b359fc82625cc9e29efb GIT binary patch literal 161826 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%0A<{uDLJNx)VJz={CocBuY%gP;gJ=>{#_MT6$ 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%0D81Ys6a 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 Jg|z=i5e@=~6VfT|e-6O*r9 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 literal 0 HcmV?d00001 diff --git a/doc/source/configuration/figures/hsp_network.png b/doc/source/configuration/figures/hsp_network.png new file mode 100644 index 0000000000000000000000000000000000000000..024ddd8c9e270265864acad3aee70160f4838647 GIT binary patch literal 155457 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

93f3pN=R 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