
On the plugin init there is a side process going over all the security group rules in the NSX DFW checking if their logging flag should be updated according to the global configuration flag. Since this is relevant only in case the global config flag log_security_groups_allowed_traffic was updated by the user, which is very rare, this patch removed it from the code, and replaced it with an admin utility that can be used. This will make the plugin initialization process quicker and prevent unnecessary load on the NSX. Change-Id: I233915e589b53ccb4b76a3ef3d24bb56c0459e92
191 lines
6.5 KiB
Python
191 lines
6.5 KiB
Python
# Copyright 2015 VMware, Inc. All rights reserved.
|
|
#
|
|
# 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.
|
|
|
|
import time
|
|
|
|
import mock
|
|
|
|
from oslo_config import cfg
|
|
from oslo_log import log as logging
|
|
|
|
from neutron.db import common_db_mixin as common_db
|
|
from neutron_lib import context as neutron_context
|
|
from neutron_lib.plugins import directory
|
|
|
|
from vmware_nsx.common import config
|
|
from vmware_nsx.extensions import projectpluginmap
|
|
from vmware_nsx import plugin
|
|
from vmware_nsx.plugins.nsx_v.vshield import vcns
|
|
from vmware_nsx.shell.admin.plugins.common import utils as admin_utils
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
def get_nsxv_client():
|
|
return vcns.Vcns(
|
|
address=cfg.CONF.nsxv.manager_uri,
|
|
user=cfg.CONF.nsxv.user,
|
|
password=cfg.CONF.nsxv.password,
|
|
ca_file=cfg.CONF.nsxv.ca_file,
|
|
insecure=cfg.CONF.nsxv.insecure)
|
|
|
|
|
|
def get_plugin_filters(context):
|
|
return admin_utils.get_plugin_filters(
|
|
context, projectpluginmap.NsxPlugins.NSX_V)
|
|
|
|
|
|
class NeutronDbClient(common_db.CommonDbMixin):
|
|
def __init__(self):
|
|
super(NeutronDbClient, self)
|
|
self.context = neutron_context.get_admin_context()
|
|
|
|
|
|
class NsxVPluginWrapper(plugin.NsxVPlugin):
|
|
|
|
def __init__(self):
|
|
config.register_nsxv_azs(cfg.CONF, cfg.CONF.nsxv.availability_zones)
|
|
self.context = neutron_context.get_admin_context()
|
|
self.filters = get_plugin_filters(self.context)
|
|
super(NsxVPluginWrapper, self).__init__()
|
|
# Make this the core plugin
|
|
directory.add_plugin('CORE', self)
|
|
# finish the plugin initialization
|
|
# (with md-proxy config, but without housekeeping)
|
|
with mock.patch("vmware_nsx.plugins.common.housekeeper."
|
|
"housekeeper.NsxHousekeeper"):
|
|
self.init_complete(0, 0, 0)
|
|
|
|
def _start_rpc_listeners(self):
|
|
pass
|
|
|
|
def _extend_get_network_dict_provider(self, context, net):
|
|
self._extend_network_dict_provider(context, net)
|
|
# skip getting the Qos policy ID because get_object calls
|
|
# plugin init again on admin-util environment
|
|
|
|
def count_spawn_jobs(self):
|
|
# check if there are any spawn jobs running
|
|
return self.edge_manager._get_worker_pool().running()
|
|
|
|
# Define enter & exit to be used in with statements
|
|
def __enter__(self):
|
|
return self
|
|
|
|
def __exit__(self, type, value, traceback):
|
|
"""Wait until no more jobs are pending
|
|
|
|
We want to wait until all spawn edge creation are done, or else the
|
|
edges might be in PERNDING_CREATE state in the nsx DB
|
|
"""
|
|
if not self.count_spawn_jobs():
|
|
return
|
|
|
|
LOG.warning("Waiting for plugin jobs to finish properly...")
|
|
sleep_time = 1
|
|
print_time = 20
|
|
max_loop = 600
|
|
for print_index in range(1, max_loop):
|
|
n_jobs = self.count_spawn_jobs()
|
|
if n_jobs > 0:
|
|
if (print_index % print_time) == 0:
|
|
LOG.warning("Still Waiting on %(jobs)s "
|
|
"job%(plural)s",
|
|
{'jobs': n_jobs,
|
|
'plural': 's' if n_jobs > 1 else ''})
|
|
time.sleep(sleep_time)
|
|
else:
|
|
LOG.warning("Done.")
|
|
return
|
|
|
|
LOG.warning("Sorry. Waited for too long. Some jobs are still "
|
|
"running.")
|
|
|
|
def _update_filters(self, requested_filters):
|
|
filters = self.filters.copy()
|
|
if requested_filters:
|
|
filters.update(requested_filters)
|
|
return filters
|
|
|
|
def get_networks(self, context, filters=None, fields=None,
|
|
filter_project=True):
|
|
if filter_project:
|
|
filters = self._update_filters(filters)
|
|
return super(NsxVPluginWrapper, self).get_networks(
|
|
context, filters=filters, fields=fields)
|
|
|
|
def get_subnets(self, context, filters=None, fields=None,
|
|
filter_project=True):
|
|
if filter_project:
|
|
filters = self._update_filters(filters)
|
|
return super(NsxVPluginWrapper, self).get_subnets(
|
|
context, filters=filters, fields=fields)
|
|
|
|
def get_ports(self, context, filters=None, fields=None,
|
|
filter_project=True):
|
|
if filter_project:
|
|
filters = self._update_filters(filters)
|
|
return super(NsxVPluginWrapper, self).get_ports(
|
|
self.context, filters=filters, fields=fields)
|
|
|
|
def get_routers(self, context, filters=None, fields=None,
|
|
filter_project=True):
|
|
if filter_project:
|
|
filters = self._update_filters(filters)
|
|
return super(NsxVPluginWrapper, self).get_routers(
|
|
self.context, filters=filters, fields=fields)
|
|
|
|
|
|
def get_nsxv_backend_edges():
|
|
"""Get a list of all the backend edges and some of their attributes
|
|
"""
|
|
nsxv = get_nsxv_client()
|
|
edges = nsxv.get_edges()
|
|
backend_edges = []
|
|
for edge in edges:
|
|
summary = edge.get('appliancesSummary')
|
|
size = ha = None
|
|
if summary:
|
|
size = summary.get('applianceSize')
|
|
deployed_vms = summary.get('numberOfDeployedVms', 1)
|
|
ha = 'Enabled' if deployed_vms > 1 else 'Disabled'
|
|
# get all the relevant backend information for this edge
|
|
edge_data = {
|
|
'id': edge.get('id'),
|
|
'name': edge.get('name'),
|
|
'size': size,
|
|
'type': edge.get('edgeType'),
|
|
'ha': ha,
|
|
}
|
|
backend_edges.append(edge_data)
|
|
return backend_edges
|
|
|
|
|
|
def get_edge_syslog_info(edge_id):
|
|
"""Get syslog information for specific edge id"""
|
|
|
|
nsxv = get_nsxv_client()
|
|
syslog_info = nsxv.get_edge_syslog(edge_id)[1]
|
|
if not syslog_info['enabled']:
|
|
return 'Disabled'
|
|
|
|
output = ""
|
|
if 'protocol' in syslog_info:
|
|
output += syslog_info['protocol']
|
|
if 'serverAddresses' in syslog_info:
|
|
for server_address in syslog_info['serverAddresses']['ipAddress']:
|
|
output += "\n" + server_address
|
|
|
|
return output
|