RETIRED, SDN based Distributed Virtual Router for OpenStack Neutron
Go to file
Gal Sagie 37d524a4e3 Enable Env for DragonFlow Unit Testing
Add missing dependencies and create empty test classes

Change-Id: I7f13da25914d1798286e6ff0936d20bbf645c3a2
2015-04-29 10:58:37 +03:00
devstack Add DVR settings for devstack plugin 2015-04-14 09:42:49 +03:00
doc Add DVR settings for devstack plugin 2015-04-14 09:42:49 +03:00
dragonflow Enable Env for DragonFlow Unit Testing 2015-04-29 10:58:37 +03:00
tools Enable Env for DragonFlow Unit Testing 2015-04-29 10:58:37 +03:00
.coveragerc Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
.gitignore Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
.gitreview Added .gitreview 2015-01-28 23:12:22 +00:00
.mailmap Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
.testr.conf Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
CONTRIBUTING.rst Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
HACKING.rst Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
LICENSE Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
MANIFEST.in Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
README.rst Minor fixes to improve README visbility 2015-03-23 10:43:22 +02:00
babel.cfg Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
neutron-l3-controller-agent Set Up the neutron l3 sdn addon using neutron as library 2015-03-01 18:16:07 +02:00
openstack-common.conf Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
requirements.txt Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
setup.cfg Add L2 Agent to Dragonflow 2015-03-08 08:42:04 +02:00
setup.py Initial Cookiecutter Commit. 2015-01-29 16:46:27 +02:00
test-requirements.txt Enable Env for DragonFlow Unit Testing 2015-04-29 10:58:37 +03:00
tox.ini Enable Env for DragonFlow Unit Testing 2015-04-29 10:58:37 +03:00

README.rst

SDN based Virtual Router add-on for Neutron OpenStack

Overview

Dragonflow is an implementation of a fully distributed virtual router for OpenStack Neutron, which is based on a Software-Defined Network Controller (SDNC) design.

The main purpose of Dragonflow is to simplify the management of the virtual router, while improving performance, scale and eliminating single point of failure and the notorious network node bottleneck.

The proposed method is based on the separation of the routing control plane from the data plane. This is accomplished by implementing the routing logic in distributed forwarding rules on the virtual switches. In OpenFlow these rules are called flows. To put this simply, the virtual router is implemented using OpenFlow flows.

Dragonflow eliminate the use of namespaces in contrast to the standard DVR, a diagram showing Dragonflow components and overall architecture can be seen here:

Solution Overview

Perhaps the most important part of the solution is the OpenFlow pipeline which we install into the integration bridge upon bootstrap. This is the flow that controls all traffic in the OVS integration bridge (br-int). The pipeline works in the following manner:

1) Classify the traffic
2) Forward to the appropriate element:
    1. If it is ARP, forward to the ARP Responder table
    2. If routing is required (L3), forward to the L3 Forwarding table
       (which implements a virtual router)
    3. All L2 traffic and local subnet traffic are offloaded to the NORMAL pipeline handled by ML2
    4. North/South traffic is forwarded to the network node (SNAT)

The following diagram shows the multi-table OpenFlow pipeline installed into the OVS integration bridge (br-int) in order to represent the virtual router using flows only:

Pipeline

A detailed blog post describing the solution can be found Here.

How to Install

https://github.com/stackforge/dragonflow/tree/master/doc/source

Prerequisites

Install DevStack with Netron ML2 as core plugin Install OVS 2.3.1 or newer

Features

  • APIs for routing IPv4 East-West traffic
  • Performance improvement for inter-subnet network by removing the amount of kernel layers (namespaces and their TCP stack overhead)
  • Scalability improvement for inter-subnet network by offloading L3 East-West routing from the Network Node to all Compute Nodes
  • Reliability improvement for inter-subnet network by removal of Network Node from the East-West traffic
  • Simplified virtual routing management
  • Supports all type drivers GRE/VXLAN (Currently doesnt support VLAN)

TODO

  • Add support for North-South L3 IPv4 distribution (SNAT and DNAT)
  • Remove change impact on Neutron L2 Agent by switching to OVSDB command for bootstrap sequence (set-controller and install arp responder)
  • Add support for IPv6
  • Support for multi controllers solution