Skip to content
AndreKutzleb edited this page Nov 10, 2015 · 105 revisions

Welcome to the ZeroSDN wiki!

What is ZSDN?

Overview

Zero Software Defined Networking (ZSDN) is a modular based SDN controller. The software is fully distributed which means there are no central instances that control the whole network. Instead it consists of multiple modules that are connected via ZMQ (see http://zeromq.org). The communication between modules is handled using google protobuffers. The execution of each module is controlled by an instance of the Zero Module Framework.

The ZSDN ModuleFramework controls the execution of a ZSDN module and connects it to the ZSDN system via ZMQ. The ZMF is used by controller modules and switch adapter modules.

An overview of the existing modules can be found here: ZSDN Modules

Working With ZSDN

Structure Of The Framework

ZeroSDN StartUpSelector initial screen

As the figure shows, the framework consists of several units: the ZMFCore, which encapsulates the main functionality of the framework such as starting and stopping of modules. Also it provides an interface that modules can use for accessing the framework and for connecting to other modules through it. These modules are always derived from the AbstractModule-class.

Furthermore, the ZMFCore controls the execution of two more essential services that are started and stopped with an instance of the ZMF. The first is called the PeerDiscoveryService which subscribes to a multicast group in the network to which all other ZMF instances also subscribe. The service frequently sends out so called heartbeats in form of udp-multicast messages. This way every instance of the ZMF knows about all other module instances that are available at this time and what state the currently have.

The ZMQMessagingService provides functionality to modules that can be used for sending direct ZMQ request messages to other modules and for receiving their replies in the same way. It can also be used to publish ZMQ messages to a certain topic or to receive messages from other modules through a preceding subscription to this topic.

Module applications call the run method of the ZMF framework (eg. from the main method) to start the ZMF instance.

For further information about ZMF see ZMF Wiki.

How to write a Module

See How-To-Write-a-Module

Working with Eclipse

As the JMF requires Java 1.8 you should be using Eclipse Luna or newer, since Luna supports Java 1.8 out of the box. The Java parts of the ZSDN should be imported into Eclipse as Maven projects in the following order: JMF -> zsdn-proto -> RESTAdminModule. This will guarantee the dependencies referencing each other properly.

Cross Compilation

See Crosscompiling_for_ARMRaspberry_Pi