NSXV: make service edge sizes configurable
Allow configuration of default sizes per edge purpose. Change-Id: I7a8dcc42144edf064435357fb555f5cbe72c92e6
This commit is contained in:
parent
abfe98d528
commit
f96384fc20
@ -20,6 +20,7 @@ from neutron.conf.db import l3_hamode_db
|
||||
|
||||
from vmware_nsx._i18n import _
|
||||
from vmware_nsx.common import exceptions as nsx_exc
|
||||
from vmware_nsx.common import nsxv_constants
|
||||
from vmware_nsx.dvs import dvs_utils
|
||||
from vmware_nsx.extensions import projectpluginmap
|
||||
from vmware_nsx.extensions import routersize
|
||||
@ -814,7 +815,13 @@ nsxv_opts = [
|
||||
default=False,
|
||||
help=_("Create LBaaS pools with transparent mode on. Use with "
|
||||
"use_routers_as_lbaas_platform enabled")),
|
||||
|
||||
cfg.ListOpt('default_edge_size',
|
||||
default=[],
|
||||
help=_("(Optional) Defines the default edge size for router, "
|
||||
"dhcp and loadbalancer edges with the format: "
|
||||
"<purpose>:<edge_size>. "
|
||||
"purpose: router, dhcp, lb. "
|
||||
"edge_size: compact, large, xlarge, quadlarge")),
|
||||
]
|
||||
|
||||
# define the configuration of each NSX-V availability zone.
|
||||
@ -1073,6 +1080,15 @@ def validate_nsxv_config_options():
|
||||
error = _("dvs host/vcenter credentials must be defined to use "
|
||||
"dvs features")
|
||||
raise nsx_exc.NsxPluginException(err_msg=error)
|
||||
for purpose_def in cfg.CONF.nsxv.default_edge_size:
|
||||
(p, s) = purpose_def.split(':')
|
||||
if p not in ['lb', 'router', 'dhcp']:
|
||||
error = _('Invalid service edge purpose %s') % p
|
||||
raise nsx_exc.NsxPluginException(err_msg=error)
|
||||
|
||||
if s not in nsxv_constants.VALID_EDGE_SIZE:
|
||||
error = _('Invalid service edge size %s') % s
|
||||
raise nsx_exc.NsxPluginException(err_msg=error)
|
||||
|
||||
|
||||
def validate_nsx_config_options():
|
||||
|
@ -19,6 +19,7 @@ LARGE = 'large'
|
||||
XLARGE = 'xlarge'
|
||||
QUADLARGE = 'quadlarge'
|
||||
|
||||
VALID_EDGE_SIZE = [COMPACT, LARGE, XLARGE, QUADLARGE]
|
||||
|
||||
EXCLUSIVE = "exclusive"
|
||||
|
||||
|
@ -66,6 +66,19 @@ SUPPORTED_EDGE_LOG_MODULES = ('routing', 'highavailability',
|
||||
SUPPORTED_EDGE_LOG_LEVELS = ('none', 'debug', 'info', 'warning', 'error')
|
||||
|
||||
|
||||
def parse_service_edge_size():
|
||||
edge_size_dict = {}
|
||||
if cfg.CONF.nsxv.default_edge_size:
|
||||
for purpose_def in cfg.CONF.nsxv.default_edge_size:
|
||||
(p, s) = purpose_def.split(':')
|
||||
edge_size_dict[p] = s
|
||||
return edge_size_dict
|
||||
|
||||
|
||||
def get_service_edge_size(size_dict, purpose):
|
||||
return size_dict.get(purpose, vcns_const.SERVICE_SIZE_MAPPING[purpose])
|
||||
|
||||
|
||||
def _get_vdr_transit_network_ipobj():
|
||||
transit_net = cfg.CONF.nsxv.vdr_transit_network
|
||||
return netaddr.IPNetwork(transit_net)
|
||||
@ -190,6 +203,10 @@ class EdgeManager(object):
|
||||
self.plugin = plugin
|
||||
self.per_interface_rp_filter = self._get_per_edge_rp_filter_state()
|
||||
self._check_backup_edge_pools()
|
||||
self._service_edge_size_dict = parse_service_edge_size()
|
||||
|
||||
def get_service_edge_size(self, purpose):
|
||||
return get_service_edge_size(self._service_edge_size_dict, purpose)
|
||||
|
||||
def _parse_backup_edge_pool_opt(self):
|
||||
"""Parse edge pool opts for all availability zones."""
|
||||
@ -847,14 +864,16 @@ class EdgeManager(object):
|
||||
_uuid())[:vcns_const.EDGE_NAME_LEN]
|
||||
self._allocate_edge_appliance(
|
||||
context, resource_id, resource_name,
|
||||
appliance_size=vcns_const.SERVICE_SIZE_MAPPING['dhcp'],
|
||||
appliance_size=self.get_service_edge_size('dhcp'),
|
||||
availability_zone=availability_zone,
|
||||
deploy_metadata=True)
|
||||
|
||||
def allocate_lb_edge_appliance(
|
||||
self, context, resource_id, availability_zone,
|
||||
appliance_size=vcns_const.SERVICE_SIZE_MAPPING['lb']):
|
||||
appliance_size=None):
|
||||
|
||||
if not appliance_size:
|
||||
appliance_size = self.get_service_edge_size('lb')
|
||||
return self._allocate_edge_appliance(
|
||||
context, resource_id, resource_id,
|
||||
appliance_size=appliance_size,
|
||||
@ -889,9 +908,11 @@ class EdgeManager(object):
|
||||
|
||||
def create_lrouter(
|
||||
self, context, lrouter, lswitch=None, dist=False,
|
||||
appliance_size=vcns_const.SERVICE_SIZE_MAPPING['router'],
|
||||
appliance_size=None,
|
||||
availability_zone=None):
|
||||
"""Create an edge for logical router support."""
|
||||
if not appliance_size:
|
||||
appliance_size = self.get_service_edge_size('router')
|
||||
router_name = self._build_lrouter_name(lrouter['id'], lrouter['name'])
|
||||
|
||||
edge_id = self._allocate_edge_appliance(
|
||||
@ -1253,7 +1274,7 @@ class EdgeManager(object):
|
||||
|
||||
def reuse_existing_dhcp_edge(self, context, edge_id, resource_id,
|
||||
network_id, availability_zone):
|
||||
app_size = vcns_const.SERVICE_SIZE_MAPPING['dhcp']
|
||||
app_size = self.get_service_edge_size('dhcp')
|
||||
# There may be edge cases when we are waiting for edges to deploy
|
||||
# and the underlying db session may hit a timeout. So this creates
|
||||
# a new session
|
||||
@ -2031,7 +2052,8 @@ def create_lrouter(nsxv_manager, context, lrouter, lswitch=None, dist=False,
|
||||
"""Create an edge for logical router support."""
|
||||
router_id = lrouter['id']
|
||||
router_name = lrouter['name'] + '-' + router_id
|
||||
appliance_size = vcns_const.SERVICE_SIZE_MAPPING['router']
|
||||
appliance_size = get_service_edge_size(parse_service_edge_size(),
|
||||
'router')
|
||||
# store router-edge mapping binding
|
||||
nsxv_db.add_nsxv_router_binding(
|
||||
context.session, router_id, None, None,
|
||||
|
@ -46,7 +46,7 @@ class EdgeLoadBalancerManagerFromDict(base_mgr.EdgeLoadbalancerBaseManager):
|
||||
|
||||
def _get_lb_flavor_size(self, context, flavor_id):
|
||||
if not flavor_id:
|
||||
return vcns_const.SERVICE_SIZE_MAPPING['lb']
|
||||
return self.core_plugin.edge_manager.get_service_edge_size('lb')
|
||||
flavor = flavors_plugin.FlavorsPlugin.get_flavor(
|
||||
self.flavor_plugin, context, flavor_id)
|
||||
flavor_size = flavor['name']
|
||||
|
@ -267,7 +267,7 @@ class TestEdgeLbaasV2LoadbalancerOnRtr(BaseTestEdgeLbaasV2):
|
||||
self.edge_driver.pool.vcns, LB_EDGE_ID, 'accept')
|
||||
mock_get_edge.assert_called_with(mock.ANY, mock.ANY, LB_ID,
|
||||
LB_VIP, mock.ANY,
|
||||
LB_TENANT_ID, 'compact')
|
||||
LB_TENANT_ID, mock.ANY)
|
||||
|
||||
mock_add_vip_fwr.assert_called_with(self.edge_driver.pool.vcns,
|
||||
LB_EDGE_ID,
|
||||
|
Loading…
x
Reference in New Issue
Block a user