Blueprint nicira-plugin-get-improvements With this patch GET operations on the Nicira plugin will not be forwarded anymore to the NVP backend. Resource operational status will be periodically retrieved from the NVP backend using a DynamicLoopingCall. The process has been designed with the aim of avoiding: 1) frequent queries to NVP for retrieving resource status 2) execution of large queries to NVP for retrieving the status of a consistent number of resources. The process can be tuned using a set of configuration variables. GET operations will now return a status which might differ from the actual status of the resource. For retrieving status in a punctual way, the field 'status' should be explicitly specified in the GET request (only 'show' support has been implemented in this patch) This patchs also makes some changes to the fake nvp api client in order to ensure each instance has a private set of dictionaries for fake nvp entities. Change-Id: Ia745b80d2826de32ba8d6883c0d6e0893047e123
158 lines
7.0 KiB
Python
158 lines
7.0 KiB
Python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
|
|
# Copyright 2012 Nicira, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
from oslo.config import cfg
|
|
|
|
|
|
class AgentModes:
|
|
AGENT = 'agent'
|
|
# TODO(armando-migliaccio): support to be added, maybe we could add a
|
|
# mixed mode to support no-downtime migrations?
|
|
AGENTLESS = 'agentless'
|
|
|
|
|
|
class MetadataModes:
|
|
DIRECT = 'access_network'
|
|
INDIRECT = 'dhcp_host_route'
|
|
|
|
|
|
nvp_opts = [
|
|
cfg.IntOpt('max_lp_per_bridged_ls', default=64,
|
|
help=_("Maximum number of ports of a logical switch on a "
|
|
"bridged transport zone (default 64)")),
|
|
cfg.IntOpt('max_lp_per_overlay_ls', default=256,
|
|
help=_("Maximum number of ports of a logical switch on an "
|
|
"overlay transport zone (default 64)")),
|
|
cfg.IntOpt('concurrent_connections', default=5,
|
|
help=_("Maximum concurrent connections")),
|
|
cfg.IntOpt('nvp_gen_timeout', default=-1,
|
|
help=_("Number of seconds a generation id should be valid for "
|
|
"(default -1 meaning do not time out)")),
|
|
cfg.StrOpt('metadata_mode', default=MetadataModes.DIRECT,
|
|
help=_("If set to access_network this enables a dedicated "
|
|
"connection to the metadata proxy for metadata server "
|
|
"access via Neutron router. If set to dhcp_host_route "
|
|
"this enables host route injection via the dhcp agent. "
|
|
"This option is only useful if running on a host that "
|
|
"does not support namespaces otherwise access_network "
|
|
"should be used.")),
|
|
cfg.StrOpt('default_transport_type', default='stt',
|
|
help=_("The default network tranport type to use (stt, gre, "
|
|
"bridge, ipsec_gre, or ipsec_stt)")),
|
|
cfg.StrOpt('agent_mode', default=AgentModes.AGENT,
|
|
help=_("The mode used to implement DHCP/metadata services."))
|
|
]
|
|
|
|
sync_opts = [
|
|
cfg.IntOpt('state_sync_interval', default=120,
|
|
help=_("Interval in seconds between runs of the state "
|
|
"synchronization task. Set it to 0 to disable it")),
|
|
cfg.IntOpt('max_random_sync_delay', default=0,
|
|
help=_("Maximum value for the additional random "
|
|
"delay in seconds between runs of the state "
|
|
"synchronization task")),
|
|
cfg.IntOpt('min_sync_req_delay', default=10,
|
|
help=_('Minimum delay, in seconds, between two state '
|
|
'synchronization queries to NVP. It must not '
|
|
'exceed state_sync_interval')),
|
|
cfg.IntOpt('min_chunk_size', default=500,
|
|
help=_('Minimum number of resources to be retrieved from NVP '
|
|
'during state synchronization'))
|
|
]
|
|
|
|
connection_opts = [
|
|
cfg.StrOpt('nvp_user',
|
|
default='admin',
|
|
help=_('User name for NVP controllers in this cluster')),
|
|
cfg.StrOpt('nvp_password',
|
|
default='admin',
|
|
secret=True,
|
|
help=_('Password for NVP controllers in this cluster')),
|
|
cfg.IntOpt('req_timeout',
|
|
default=30,
|
|
help=_('Total time limit for a cluster request')),
|
|
cfg.IntOpt('http_timeout',
|
|
default=10,
|
|
help=_('Time before aborting a request')),
|
|
cfg.IntOpt('retries',
|
|
default=2,
|
|
help=_('Number of time a request should be retried')),
|
|
cfg.IntOpt('redirects',
|
|
default=2,
|
|
help=_('Number of times a redirect should be followed')),
|
|
cfg.ListOpt('nvp_controllers',
|
|
help=_("Lists the NVP controllers in this cluster")),
|
|
]
|
|
|
|
cluster_opts = [
|
|
cfg.StrOpt('default_tz_uuid',
|
|
help=_("This is uuid of the default NVP Transport zone that "
|
|
"will be used for creating tunneled isolated "
|
|
"\"Neutron\" networks. It needs to be created in NVP "
|
|
"before starting Neutron with the nvp plugin.")),
|
|
cfg.StrOpt('nvp_cluster_uuid',
|
|
help=_("Optional paramter identifying the UUID of the cluster "
|
|
"in NVP. This can be retrieved from NVP management "
|
|
"console \"admin\" section.")),
|
|
cfg.StrOpt('default_l3_gw_service_uuid',
|
|
help=_("Unique identifier of the NVP L3 Gateway service "
|
|
"which will be used for implementing routers and "
|
|
"floating IPs")),
|
|
cfg.StrOpt('default_l2_gw_service_uuid',
|
|
help=_("Unique identifier of the NVP L2 Gateway service "
|
|
"which will be used by default for network gateways")),
|
|
cfg.StrOpt('default_interface_name', default='breth0',
|
|
help=_("Name of the interface on a L2 Gateway transport node"
|
|
"which should be used by default when setting up a "
|
|
"network connection")),
|
|
]
|
|
|
|
# Register the configuration options
|
|
cfg.CONF.register_opts(connection_opts)
|
|
cfg.CONF.register_opts(cluster_opts)
|
|
cfg.CONF.register_opts(nvp_opts, "NVP")
|
|
cfg.CONF.register_opts(sync_opts, "NVP_SYNC")
|
|
|
|
# NOTE(armando-migliaccio): keep the following code until we support
|
|
# NVP configuration files in older format (Grizzly or older).
|
|
# ### BEGIN
|
|
controller_depr = cfg.MultiStrOpt('nvp_controller_connection',
|
|
help=_("Describes a connection to a single "
|
|
"controller. A different connection "
|
|
"for each controller in the cluster "
|
|
"can be specified; there must be at "
|
|
"least one connection per cluster."))
|
|
|
|
host_route_depr = cfg.BoolOpt('metadata_dhcp_host_route', default=None)
|
|
|
|
|
|
def register_deprecated(conf):
|
|
conf.register_opts([host_route_depr])
|
|
multi_parser = cfg.MultiConfigParser()
|
|
read_ok = multi_parser.read(conf.config_file)
|
|
if len(read_ok) != len(conf.config_file):
|
|
raise cfg.Error("Some config files were not parsed properly")
|
|
|
|
for parsed_file in multi_parser.parsed:
|
|
for section in parsed_file.keys():
|
|
if not section.lower().startswith("cluster:"):
|
|
continue
|
|
|
|
section = 'CLUSTER:' + section.split(':', 1)[1]
|
|
if section not in conf:
|
|
conf.register_opts(cluster_opts + [controller_depr], section)
|
|
# ### END
|