GithubHelp home page GithubHelp logo

dariobanfi / multipath-sdn-controller Goto Github PK

View Code? Open in Web Editor NEW
53.0 8.0 22.0 332 KB

๐ŸŽ› Multipath Software Defined Networking Controller which sets up multipath forwarding tables and adjusts them based on network measurements

Python 98.98% Shell 1.02%
software-defined-network sdn multipath multipath-sdn-controller networking

multipath-sdn-controller's Introduction

Multipath SDN Controller

This SDN Controller runs on top of a multipath network and sets up optimal multipath forwarding flow tables to maximize throughput. It uses Ryu and can be tested on an emulated network such as Mininet.

Dependencies

The controller requires a modified version of OpenvSwitch in order to run. It can be found in the following repositories, togheter with information about its modifications: https://github.com/dariobanfi/ovs-multipath

Architecture

The controller therefore has three logic components:

  • Topology Discovery Component This component is used to discover the SDN switches connected to the controller and have knowledge of the paths between them. This can be automatically be done on L2 Topologies through the Link Layer Discovery Protocol (LLDP) but can be more complex over network-layer routing and require a manual con guration (done through REST APIs).
  • Multipath Routing Component It uses the network knowledge to compute multiple paths and push the resulting computation as ow rules to the SDN switches. The rules can be a simple forward or a multipath forward, which splits the ow packets over two or more routes. The controller might additionally set up packet reordering rules at a switch that
  • Network Measurement Component This component is used to do real-time measurements of the network. The con- troller keeps an estimate of the latency and bandwidth of the multiple paths that connect the SDN switches of the multipath topology. This data is used by the multipath routing component to compute forwarding tables which maximize the throughput between the nodes.

Demo

Check out a visualization of the network benefits over here: https://www.youtube.com/watch?v=hkgf7l9Lshw&feature=youtu.be

To run the demo make sure to install the dependencies with pip (like bottle, ryu, etc) and to provide a video file to be streamed

multipath-sdn-controller's People

Contributors

dariobanfi avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

multipath-sdn-controller's Issues

how to get the demo running?

Hi
I have already get the ovs-multipath installed. But when I run ./demo.py, It waning permission denied. Any help will be great appreciated.

problem streaming video

Hi
i followed all the instructions but i've got a problem , streaming doesn't work
can you help me please

Changing the video path doesn't help.Dario help me!

Hey Dario, I came across the below error while running demo.py. Seeking your help and would certainly appreciate if you could share some insights on this...

2Traceback (most recent call last):
File "/home/river/sdncontroller/controller/mpsdn_controller.py", line 341, in probe_packet_handler
send_dpid = int(data[0])
ValueError: invalid literal for int() with base 10: ''
Unable to parse incoming probe packet
Traceback (most recent call last)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.