Skip to content

This project was completed on December 12, 2014. It's a fully functioning SDN in which a Controller machine can choose routes that hosts will use to send messages over the network. This can be dynamically during traffic exchange and is extremely applicable in Data Centers for load balancing. To learn more, view the readme.

Notifications You must be signed in to change notification settings

bnurbekov/Software_Defined_Network

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Synopsis

This project implements a Software Defined Network. An SDN effectively allows a Controller to sit on a network and give Hosts commands to modify routes, firewall rules, NAT settings, network discovery caches, etc. while the network is still operating. The ability to change the network on the fly is extremely practical, and is commonly used in LANs, WANs, and Data Centers. For more details on the project implementation, view the DESIGN.md file.

Motivation

The SDN project was assigned as a seven week project during a Advanced Networks course at my college.

Creation

The project was completed on December 12, 2014 by myself and my project partner, Batyrlan Nurbekov. We chose to use object-oriented design techniques with C++ in order to keep things organized.

We tested the system on a network of 6 VMs all running Ubuntu Linux. These VMs included a DNS Server (using BIND 9), a Controller, and four Hosts.

Installation

As this was a school project, it was not meant to be distributed and used. Nonetheless, it's certainly possible to recreate the environment we used. As long as the Hosts can reach the Controller and vice versa, building the project is just a matter of running make on each machine and spinning up the program.

About

This project was completed on December 12, 2014. It's a fully functioning SDN in which a Controller machine can choose routes that hosts will use to send messages over the network. This can be dynamically during traffic exchange and is extremely applicable in Data Centers for load balancing. To learn more, view the readme.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 99.4%
  • Makefile 0.6%