Merge "NSX: Sync do not pass around model object"
This commit is contained in:
commit
dd800bf096
@ -15,6 +15,8 @@
|
|||||||
|
|
||||||
import random
|
import random
|
||||||
|
|
||||||
|
from sqlalchemy.orm import exc
|
||||||
|
|
||||||
from neutron.common import constants
|
from neutron.common import constants
|
||||||
from neutron.common import exceptions
|
from neutron.common import exceptions
|
||||||
from neutron import context
|
from neutron import context
|
||||||
@ -235,17 +237,6 @@ class NsxSynchronizer():
|
|||||||
def _get_tag_dict(self, tags):
|
def _get_tag_dict(self, tags):
|
||||||
return dict((tag.get('scope'), tag['tag']) for tag in tags)
|
return dict((tag.get('scope'), tag['tag']) for tag in tags)
|
||||||
|
|
||||||
def _update_neutron_object(self, context, neutron_data, status):
|
|
||||||
if status == neutron_data['status']:
|
|
||||||
# do nothing
|
|
||||||
return
|
|
||||||
with context.session.begin(subtransactions=True):
|
|
||||||
LOG.debug(_("Updating status for neutron resource %(q_id)s to: "
|
|
||||||
"%(status)s"), {'q_id': neutron_data['id'],
|
|
||||||
'status': status})
|
|
||||||
neutron_data['status'] = status
|
|
||||||
context.session.add(neutron_data)
|
|
||||||
|
|
||||||
def synchronize_network(self, context, neutron_network_data,
|
def synchronize_network(self, context, neutron_network_data,
|
||||||
lswitches=None):
|
lswitches=None):
|
||||||
"""Synchronize a Neutron network with its NSX counterpart.
|
"""Synchronize a Neutron network with its NSX counterpart.
|
||||||
@ -286,7 +277,22 @@ class NsxSynchronizer():
|
|||||||
if lswitches:
|
if lswitches:
|
||||||
status = constants.NET_STATUS_ACTIVE
|
status = constants.NET_STATUS_ACTIVE
|
||||||
# Update db object
|
# Update db object
|
||||||
self._update_neutron_object(context, neutron_network_data, status)
|
if status == neutron_network_data['status']:
|
||||||
|
# do nothing
|
||||||
|
return
|
||||||
|
|
||||||
|
with context.session.begin(subtransactions=True):
|
||||||
|
try:
|
||||||
|
network = self._plugin._get_network(context,
|
||||||
|
neutron_network_data['id'])
|
||||||
|
except exc.NoResultFound:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
network.status = status
|
||||||
|
LOG.debug(_("Updating status for neutron resource %(q_id)s to:"
|
||||||
|
" %(status)s"),
|
||||||
|
{'q_id': neutron_network_data['id'],
|
||||||
|
'status': status})
|
||||||
|
|
||||||
def _synchronize_lswitches(self, ctx, ls_uuids, scan_missing=False):
|
def _synchronize_lswitches(self, ctx, ls_uuids, scan_missing=False):
|
||||||
if not ls_uuids and not scan_missing:
|
if not ls_uuids and not scan_missing:
|
||||||
@ -309,8 +315,11 @@ class NsxSynchronizer():
|
|||||||
filters = {'router:external': [False]}
|
filters = {'router:external': [False]}
|
||||||
if not scan_missing:
|
if not scan_missing:
|
||||||
filters['id'] = neutron_net_ids
|
filters['id'] = neutron_net_ids
|
||||||
networks = self._plugin._get_collection_query(
|
|
||||||
ctx, models_v2.Network, filters=filters)
|
networks = self._plugin._get_collection(
|
||||||
|
ctx, models_v2.Network, self._plugin._make_network_dict,
|
||||||
|
filters=filters)
|
||||||
|
|
||||||
for network in networks:
|
for network in networks:
|
||||||
lswitches = neutron_nsx_mappings.get(network['id'], [])
|
lswitches = neutron_nsx_mappings.get(network['id'], [])
|
||||||
lswitches = [lswitch.get('data') for lswitch in lswitches]
|
lswitches = [lswitch.get('data') for lswitch in lswitches]
|
||||||
@ -350,7 +359,22 @@ class NsxSynchronizer():
|
|||||||
constants.NET_STATUS_ACTIVE
|
constants.NET_STATUS_ACTIVE
|
||||||
or constants.NET_STATUS_DOWN)
|
or constants.NET_STATUS_DOWN)
|
||||||
# Update db object
|
# Update db object
|
||||||
self._update_neutron_object(context, neutron_router_data, status)
|
if status == neutron_router_data['status']:
|
||||||
|
# do nothing
|
||||||
|
return
|
||||||
|
|
||||||
|
with context.session.begin(subtransactions=True):
|
||||||
|
try:
|
||||||
|
router = self._plugin._get_router(context,
|
||||||
|
neutron_router_data['id'])
|
||||||
|
except exc.NoResultFound:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
router.status = status
|
||||||
|
LOG.debug(_("Updating status for neutron resource %(q_id)s to:"
|
||||||
|
" %(status)s"),
|
||||||
|
{'q_id': neutron_router_data['id'],
|
||||||
|
'status': status})
|
||||||
|
|
||||||
def _synchronize_lrouters(self, ctx, lr_uuids, scan_missing=False):
|
def _synchronize_lrouters(self, ctx, lr_uuids, scan_missing=False):
|
||||||
if not lr_uuids and not scan_missing:
|
if not lr_uuids and not scan_missing:
|
||||||
@ -372,8 +396,9 @@ class NsxSynchronizer():
|
|||||||
# Fetch neutron routers from database
|
# Fetch neutron routers from database
|
||||||
filters = ({} if scan_missing else
|
filters = ({} if scan_missing else
|
||||||
{'id': neutron_router_mappings.keys()})
|
{'id': neutron_router_mappings.keys()})
|
||||||
routers = self._plugin._get_collection_query(
|
routers = self._plugin._get_collection(
|
||||||
ctx, l3_db.Router, filters=filters)
|
ctx, l3_db.Router, self._plugin._make_router_dict,
|
||||||
|
filters=filters)
|
||||||
for router in routers:
|
for router in routers:
|
||||||
lrouter = neutron_router_mappings.get(router['id'])
|
lrouter = neutron_router_mappings.get(router['id'])
|
||||||
self.synchronize_router(
|
self.synchronize_router(
|
||||||
@ -427,8 +452,24 @@ class NsxSynchronizer():
|
|||||||
status = (lp_status and
|
status = (lp_status and
|
||||||
constants.PORT_STATUS_ACTIVE
|
constants.PORT_STATUS_ACTIVE
|
||||||
or constants.PORT_STATUS_DOWN)
|
or constants.PORT_STATUS_DOWN)
|
||||||
|
|
||||||
# Update db object
|
# Update db object
|
||||||
self._update_neutron_object(context, neutron_port_data, status)
|
if status == neutron_port_data['status']:
|
||||||
|
# do nothing
|
||||||
|
return
|
||||||
|
|
||||||
|
with context.session.begin(subtransactions=True):
|
||||||
|
try:
|
||||||
|
port = self._plugin._get_port(context,
|
||||||
|
neutron_port_data['id'])
|
||||||
|
except exc.NoResultFound:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
port.status = status
|
||||||
|
LOG.debug(_("Updating status for neutron resource %(q_id)s to:"
|
||||||
|
" %(status)s"),
|
||||||
|
{'q_id': neutron_port_data['id'],
|
||||||
|
'status': status})
|
||||||
|
|
||||||
def _synchronize_lswitchports(self, ctx, lp_uuids, scan_missing=False):
|
def _synchronize_lswitchports(self, ctx, lp_uuids, scan_missing=False):
|
||||||
if not lp_uuids and not scan_missing:
|
if not lp_uuids and not scan_missing:
|
||||||
@ -457,8 +498,9 @@ class NsxSynchronizer():
|
|||||||
external_net_db.ExternalNetwork,
|
external_net_db.ExternalNetwork,
|
||||||
(models_v2.Network.id ==
|
(models_v2.Network.id ==
|
||||||
external_net_db.ExternalNetwork.network_id))]
|
external_net_db.ExternalNetwork.network_id))]
|
||||||
ports = self._plugin._get_collection_query(
|
ports = self._plugin._get_collection(
|
||||||
ctx, models_v2.Port, filters=filters)
|
ctx, models_v2.Port, self._plugin._make_port_dict,
|
||||||
|
filters=filters)
|
||||||
for port in ports:
|
for port in ports:
|
||||||
lswitchport = neutron_port_mappings.get(port['id'])
|
lswitchport = neutron_port_mappings.get(port['id'])
|
||||||
self.synchronize_port(
|
self.synchronize_port(
|
||||||
@ -599,13 +641,12 @@ class NsxSynchronizer():
|
|||||||
# Get an admin context
|
# Get an admin context
|
||||||
ctx = context.get_admin_context()
|
ctx = context.get_admin_context()
|
||||||
# Synchronize with database
|
# Synchronize with database
|
||||||
with ctx.session.begin(subtransactions=True):
|
self._synchronize_lswitches(ctx, ls_uuids,
|
||||||
self._synchronize_lswitches(ctx, ls_uuids,
|
scan_missing=scan_missing)
|
||||||
scan_missing=scan_missing)
|
self._synchronize_lrouters(ctx, lr_uuids,
|
||||||
self._synchronize_lrouters(ctx, lr_uuids,
|
scan_missing=scan_missing)
|
||||||
|
self._synchronize_lswitchports(ctx, lp_uuids,
|
||||||
scan_missing=scan_missing)
|
scan_missing=scan_missing)
|
||||||
self._synchronize_lswitchports(ctx, lp_uuids,
|
|
||||||
scan_missing=scan_missing)
|
|
||||||
# Increase chunk counter
|
# Increase chunk counter
|
||||||
LOG.info(_("Synchronization for chunk %(chunk_num)d of "
|
LOG.info(_("Synchronization for chunk %(chunk_num)d of "
|
||||||
"%(total_chunks)d performed"),
|
"%(total_chunks)d performed"),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user