Currently, most plugin implementations releated L3 override the L3NatAgent class itself for their own logic since there is no proper interface to extend RouterInfo class. This adds unnecessary complexity for developers who just want to extend agent mechanism instead of whole RPC related to L3 functinalities. This spec introduces RouterFactory class which acts on the factory for creating RouterInfo class, and add new l3 extension API which enable to dynamically add RouterInfo to the factory. Now plugin developers can use new extension API for their own specific router. Change-Id: Ic3486830e449f6ee8dbe19db614179b2077bcf7b Related-Bug: #1804634 Implements: blueprint router-factory-with-l3-extension
4.9 KiB
Registering RouterInfo by L3 extension API
Launchpad blueprint: https://blueprints.launchpad.net/neutron/+spec/router-factory-with-l3-extension
Currently, most plugin implementations related to L3 override the L3NATAgent class itself for their own logic since there is no proper interface to extend the RouterInfo class. This adds unnecessary complexity for developers who just want to extend the agent mechanism instead of the whole RPC related to L3 functionalities.
This spec introduces the RouterFactory class which acts on the factory for creating the RouterInfo class, and adds a new parameter to the L3 agent extension API which enables it to dynamically register RouterInfo to the factory. Now plugin developers can use the new extension API for their own specific router.
Problem Description
Current L3 agent implementation in Neutron consists of two parts in general. One is to implement an RPC Plugin API from Neutron server, and the other is to create ports, namespaces, and iptables rules using the data obtained from the RPC API on the server. To be more specific, the former is the L3NATAgent class and the latter is the RouterInfo class.
The problem is that the two parts mentioned are now tightly coupled which means there is no clear way to extend each part individually. A lot of projects related to Neutron called networking-*1,2,3 are making new L3 agent classes on their own by extending the L3NATAgent class even though they did not modify the RPC mechanism but only changed the RouterInfo mechanism running on their server.
Also, the current RouterInfo class does not have an abstract interface which makes it harder to extend the class for plugin developers. They have to find what functions and variables in RouterInfo are externally used in the L3 agent to extend the RouterInfo behaviors.
Proposed Change
Today, RouterInfo is extended in several ways according to
specific router features such as distributed, ha, and distributed + ha.
This document proposes changing the L3 agent to have a new class called
RouterFactory
which has several pre-registered classes to
extend the RouterInfo class with certain features. When it
comes to creating an actual RouterInfo instance, the L3 agent
create a new instance from the RouterFactory
following the
features of the router. There is no functional change for existing
code.
L3AgentExtensionAPI now has a new parameter
router_factory
and a new function
register_router
. A new abstract class called
BaseRouterInfo
will be added. It will declare interfaces
that are currently used externally.
An L3 extension can register their own RouterInfo class
which implements BaseRouterInfo
using the
register_router
API which has two parameters.
router
: RouterInfo declared in extension which overrides the one pre-registered atRouterFactory
features
: features of RouterInfo. Currently it should be one of the below.Features should be a list of strings describing router characteristics, and the ordering does not matter since it is interpreted as a set internally. (
['ha', 'distributed']
and['distributed', 'ha']
are the same)[]
: No feature. (e.g.LegacyRouter
)['distributed']
: Distributed router. (e.g.DvrEdgeRouter
,-
DvrLocalRouter
)
['ha']
: HA router. (e.g.HaRouter
)['ha', 'distributed']
: Distributed HA router. (e.g.-
DvrEdgeHaRouter
,DvrLocalRouter
)
Note that a router with the feature of
['ha', 'distributed']
can beDvrLocalRouter
when L3 agent mode is notdvr_snat
4.
L3 extensions can override the RouterInfo class implemented in the Neutron codebase when it is initialized using the initialize function.
Implementation
Assignee(s)
- Yang Youseok <ileixe@gmail.com>
Work Items
- Add RouterInfo registration in L3AgentExensionAPI and pre-register existing RouterInfo to L3NATAgent.5
- Add new exception named RouterNotFoundInRouterFactory to neutron_lib. 6
References
`networking-odl`: https://github.com/openstack/networking-odl/blob/master/networking_odl/l3/l3_odl_v2.py#L47↩︎
`networking-ovn`: https://github.com/openstack/networking-ovn/blob/master/networking_ovn/l3/l3_ovn.py#L50↩︎
`networking-calico`: https://github.com/openstack/networking-calico/blob/master/networking_calico/plugins/calico/plugin.py#L26↩︎
https://docs.openstack.org/neutron/latest/configuration/l3-agent.html#DEFAULT.agent_mode↩︎