[OVN] Introduce the new OVN Neutron Agent
This patch introduces the new OVN Neutron Agent definition in the OVN agent list and creates a new class ``OVNNeutronAgent``. Related-Bug: #1998608 Change-Id: I57de801473fc30f06acf1bc8a65cb2ff76b2954a
This commit is contained in:
parent
b6750fb2b8
commit
78c3d52bb4
@ -74,9 +74,13 @@ OVN_AGENT_DESC_KEY = 'neutron:description'
|
|||||||
OVN_AGENT_METADATA_SB_CFG_KEY = 'neutron:ovn-metadata-sb-cfg'
|
OVN_AGENT_METADATA_SB_CFG_KEY = 'neutron:ovn-metadata-sb-cfg'
|
||||||
OVN_AGENT_METADATA_DESC_KEY = 'neutron:description-metadata'
|
OVN_AGENT_METADATA_DESC_KEY = 'neutron:description-metadata'
|
||||||
OVN_AGENT_METADATA_ID_KEY = 'neutron:ovn-metadata-id'
|
OVN_AGENT_METADATA_ID_KEY = 'neutron:ovn-metadata-id'
|
||||||
|
OVN_AGENT_NEUTRON_SB_CFG_KEY = 'neutron:ovn-neutron-agent-sb-cfg'
|
||||||
|
OVN_AGENT_NEUTRON_DESC_KEY = 'neutron:description-neutron-agent'
|
||||||
|
OVN_AGENT_NEUTRON_ID_KEY = 'neutron:ovn-neutron-agent-id'
|
||||||
OVN_CONTROLLER_AGENT = 'OVN Controller agent'
|
OVN_CONTROLLER_AGENT = 'OVN Controller agent'
|
||||||
OVN_CONTROLLER_GW_AGENT = 'OVN Controller Gateway agent'
|
OVN_CONTROLLER_GW_AGENT = 'OVN Controller Gateway agent'
|
||||||
OVN_METADATA_AGENT = 'OVN Metadata agent'
|
OVN_METADATA_AGENT = 'OVN Metadata agent'
|
||||||
|
OVN_NEUTRON_AGENT = 'OVN Neutron agent'
|
||||||
OVN_CONTROLLER_TYPES = (OVN_CONTROLLER_AGENT,
|
OVN_CONTROLLER_TYPES = (OVN_CONTROLLER_AGENT,
|
||||||
OVN_CONTROLLER_GW_AGENT,
|
OVN_CONTROLLER_GW_AGENT,
|
||||||
)
|
)
|
||||||
|
@ -220,6 +220,41 @@ class MetadataAgent(NeutronAgent):
|
|||||||
ovn_const.OVN_AGENT_METADATA_DESC_KEY, '')
|
ovn_const.OVN_AGENT_METADATA_DESC_KEY, '')
|
||||||
|
|
||||||
|
|
||||||
|
class OVNNeutronAgent(NeutronAgent):
|
||||||
|
agent_type = ovn_const.OVN_NEUTRON_AGENT
|
||||||
|
binary = 'neutron-ovn-agent'
|
||||||
|
|
||||||
|
@property
|
||||||
|
def alive(self):
|
||||||
|
# If ovn-controller is down, then OVN Neutron Agent is down even
|
||||||
|
# if the neutron-ovn-agent binary is updating external_ids.
|
||||||
|
try:
|
||||||
|
if not AgentCache()[self.chassis_private.name].alive:
|
||||||
|
return False
|
||||||
|
except KeyError:
|
||||||
|
return False
|
||||||
|
return super().alive
|
||||||
|
|
||||||
|
@property
|
||||||
|
def nb_cfg(self):
|
||||||
|
return int(self.chassis_private.external_ids.get(
|
||||||
|
ovn_const.OVN_AGENT_NEUTRON_SB_CFG_KEY, 0))
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def id_from_chassis_private(chassis_private):
|
||||||
|
return chassis_private.external_ids.get(
|
||||||
|
ovn_const.OVN_AGENT_NEUTRON_ID_KEY)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def agent_id(self):
|
||||||
|
return self.id_from_chassis_private(self.chassis_private)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def description(self):
|
||||||
|
return self.chassis_private.external_ids.get(
|
||||||
|
ovn_const.OVN_AGENT_NEUTRON_DESC_KEY, '')
|
||||||
|
|
||||||
|
|
||||||
@utils.SingletonDecorator
|
@utils.SingletonDecorator
|
||||||
class AgentCache:
|
class AgentCache:
|
||||||
def __init__(self, driver=None):
|
def __init__(self, driver=None):
|
||||||
|
Loading…
Reference in New Issue
Block a user