neutron-specs/specs/juno/opencontrail-plugin.rst

218 lines
5.2 KiB
ReStructuredText

==========================================
Neutron Plugin for Opencontrail
==========================================
https://blueprints.launchpad.net/neutron/+spec/juniper-plugin-with-extensions
This blueprint is for the Opencontrail-neutron-plugin to add support in Neutron
for Opencontrail based network virtualization. The list of core resources and
extensions supported are:
* Network
* Subnet
* Port
* Security Group
* L3 Extensions
We will also support Extraroute extension
Problem description
===================
Opencontrail is open source network virtualization solution. It uses standards
based BGP L3VPN closed user groups to implement virtual networks.
The link http://opencontrail.org/opencontrail-architecture-documentation/
explains the architecture of Opencontrail plugin
The Neutron plugin code would interact with Opencontrail Rest-API to provide
the network virtualization functionality.
Proposed change
===============
The Opencontrail Neutron plugin will implement the Neutron core and extension
APIs. It will receive the API request and pass it to the Opencontrail controller
for processing.
There are no changes to the Neutron common code. New files are addded to
implement the opencontrail-plugin.
Alternatives
------------
Current support is for traditional Neutron plugin interface.
We will consider using ML2 interface in future.
Data model impact
-----------------
None.
REST API impact
---------------
None.
There are no new API added to neutron. For above listed API all features
will be supported by the plugin.
Security impact
---------------
The communication channel to the backend is not secure.
We will support secure channel in the future.
Notifications impact
--------------------
None.
Other end user impact
---------------------
Users will now be able to configure Opencontrail as one of the available plugin
from upstream.
Performance Impact
------------------
None.
Other deployer impact
---------------------
Users will now be able to configure Opencontrail as one of the available plugin
from upstream. Following link explains setup of Opencontrail using devstack.
http://pedrormarques.wordpress.com/2013/11/14/using-devstack-plus-opencontrail/
Developer impact
----------------
None.
Other Developers wont be effected by this change. Tempest thirdparty environment
will be provided.
Implementation
==============
Opencontrail plugin does not use the Neutron persistence layer and so avoid
the problems when the database goes out of sync. Opencontrail plugin uses
additional objects and attributes for objects that are defined by Neutron
APIs, that data is stored in the Opencontrail controller which does the
persistency. By being stateless, the Neutron service doesn't have to deal
with its persistency layer getting out of sync with the implementation's
persistence layer.
A New Plugin 'opencontrail' has been created. A new file
'contrail_plugin.py' has been added to implement the core extension
RESTApi.
The configuration file contrailplugin.ini will be added to configure the
Opencontrail plugin. The file will contain the following parameters.
1 api_server_ip
The Opencontrail controller IP address
2 api_server_port
The Opencontrail controller IP port
3 multi-tenancy
Multi-tenancy support
4 max_retries
The maximum number of tries to connect to the Opencontrail controller
5 retry_interval
Retry interval to connect to the Opencontrail controller
Example:
[API_SERVER]
api_server_ip = 10.10.10.10
api_server_port = 8082
multi_tenancy = False
The Class 'NeutronPluginContrailCoreV2' is added to implement the core RESTApi.
It will implement the following extensions and their RESTApis
Network
- create_network
- update_network
- delete_network
- get_network
- get_networks
- get_networks_count
Subnet
- create_subnet
- update_subnet
- delete_subnet
- get_subnet
- get_subnets
- get_subnets_count
Port
- create_port
- update_port
- delete_port
- get_port
- get_ports
- get_ports_count
Router
- create_router
- update_router
- delete_router
- get_router
- get_routers
- get_routers_count
Floatingip
- create_floatingip
- update_floatingip
- delete_floatingip
- get_floatingip
- get_floatingips
- get_floatingips_count
SecurityGroup
- create_security_group
- update_security_group
- delete_security_group
- get_security_group
- get_security_groups
- get_security_groups_count
Assignee(s)
-----------
Primary assignee:
praneetb
Other contributors:
hajay
Work Items
----------
1. Opencontrail plugin implementation
2. Opencontrail mocks for unit-tests
Dependencies
============
None.
Testing
=======
Existing and new (added in Juno) Neutron unit tests will be used.
Existing and new tempest testing for neutron will be used.
Tempest CI environment will be provided.
Documentation Impact
====================
Once the opencontrail neutron plugin is accepted, neutron documentation can
change to say opencontrail plugin as one of the supported plugin.
The link below explains setup of Opencontrail using devstack.
http://pedrormarques.wordpress.com/2013/11/14/using-devstack-plus-opencontrail/
References
==========
http://www.opencontrail.org
https://github.com/Juniper/contrail-controller