Add script to clean up all backup edges owned by Neutron
When Neutron server is deleted, we need to clean up all backup edges created by neutron server. The current clean-all cannot address the scenario that many neutron servers are using same NSXv backend. Change-Id: I4f4d19adf7293c2c91c2cd8b52359bb1eb338b84
This commit is contained in:
parent
5119fd0355
commit
998a245512
@ -127,9 +127,9 @@ Backup Edges
|
|||||||
|
|
||||||
nsxadmin -r backup-edges -o clean --property edge-id=edge-9 [--force]
|
nsxadmin -r backup-edges -o clean --property edge-id=edge-9 [--force]
|
||||||
|
|
||||||
- Delete all backup edges::
|
- Delete all backup edges existing in both neutron and backend when scope is neutron, else backend only::
|
||||||
|
|
||||||
nsxadmin -r backup-edges -o clean-all [--force]
|
nsxadmin -r backup-edges -o clean-all --property scope=[neutron/all] [--force]
|
||||||
|
|
||||||
- List Edge name mismatches between DB and backend, and backup edges that are missing from the backend::
|
- List Edge name mismatches between DB and backend, and backup edges that are missing from the backend::
|
||||||
|
|
||||||
|
@ -37,7 +37,7 @@ nsxv = utils.get_nsxv_client()
|
|||||||
_uuid = uuidutils.generate_uuid
|
_uuid = uuidutils.generate_uuid
|
||||||
|
|
||||||
|
|
||||||
def get_nsxv_backup_edges():
|
def get_nsxv_backup_edges(scope="all"):
|
||||||
edges = utils.get_nsxv_backend_edges()
|
edges = utils.get_nsxv_backend_edges()
|
||||||
backup_edges = []
|
backup_edges = []
|
||||||
edgeapi = utils.NeutronDbClient()
|
edgeapi = utils.NeutronDbClient()
|
||||||
@ -46,6 +46,16 @@ def get_nsxv_backup_edges():
|
|||||||
# Make sure it is really a backup edge
|
# Make sure it is really a backup edge
|
||||||
edge_vnic_binds = nsxv_db.get_edge_vnic_bindings_by_edge(
|
edge_vnic_binds = nsxv_db.get_edge_vnic_bindings_by_edge(
|
||||||
edgeapi.context.session, edge['id'])
|
edgeapi.context.session, edge['id'])
|
||||||
|
if scope != "all":
|
||||||
|
# Make sure the backup edge exists in neutron
|
||||||
|
# Return backup edges existing in both neutron and backend
|
||||||
|
# when scope != all
|
||||||
|
edge_in_neutron = nsxv_db.get_nsxv_router_binding_by_edge(
|
||||||
|
edgeapi.context.session, edge['id'])
|
||||||
|
if not edge_vnic_binds and edge_in_neutron:
|
||||||
|
extend_edge_info(edge)
|
||||||
|
backup_edges.append(edge)
|
||||||
|
else:
|
||||||
if not edge_vnic_binds:
|
if not edge_vnic_binds:
|
||||||
extend_edge_info(edge)
|
extend_edge_info(edge)
|
||||||
backup_edges.append(edge)
|
backup_edges.append(edge)
|
||||||
@ -138,7 +148,15 @@ def nsx_clean_backup_edge(resource, event, trigger, **kwargs):
|
|||||||
|
|
||||||
def nsx_clean_all_backup_edges(resource, event, trigger, **kwargs):
|
def nsx_clean_all_backup_edges(resource, event, trigger, **kwargs):
|
||||||
"""Delete all backup edges"""
|
"""Delete all backup edges"""
|
||||||
backup_edges = get_nsxv_backup_edges()
|
scope = "all"
|
||||||
|
if kwargs.get('property'):
|
||||||
|
properties = admin_utils.parse_multi_keyval_opt(kwargs['property'])
|
||||||
|
scope = properties.get("scope", "all")
|
||||||
|
if scope not in ["neutron", "all"]:
|
||||||
|
LOG.error("Need to specify the scope in ['neutron', 'all']")
|
||||||
|
return
|
||||||
|
|
||||||
|
backup_edges = get_nsxv_backup_edges(scope=scope)
|
||||||
|
|
||||||
if not kwargs.get('force'):
|
if not kwargs.get('force'):
|
||||||
#ask for the user confirmation
|
#ask for the user confirmation
|
||||||
|
Loading…
x
Reference in New Issue
Block a user