Skip to main content

Your submission was sent successfully! Close

Thank you for signing up for our newsletter!
In these regular emails you will find the latest updates from Canonical and upcoming events where you can meet our team.Close

Thank you for contacting our team. We will be in touch shortly.Close

  1. Blog
  2. Article

Fouaz Bouguerra
on 11 October 2021


This blog post is part of our data centre networking series:

In the precedent blog, we provided an introduction to Software-Defined Networking (SDN) and the main reasons which compelled the industry to adopt it. We’ve seen how impactful it can be to leverage scalable automation and the power of software to define and run key networking components. Being sufficiently granular to address functions such as switching, routing, security and QoS, provides strong benefits to the organisations’ IT teams. Going further, making those networking functions model-driven and tied to the end-user’s application intent will highly improve the business applications’ outcomes. In this blog, we will cover the principal components of SDN, its architecture and different types.

Software-defined networking architecture

The SDN network components can be represented into three layers:

  • The application layer, which provides network “applications” that can be used on demand by users to transmit information about network-specific requests.
  • The control layer, which includes the SDN controllers and interacts with the applications to provide the destination of the data traffic.
  • The infrastructure layer, which includes all the SDN networking devices responsible for the traffic forwarding.

The communication between the different layers is done using OpenFlow, a standardised and programmable networking protocol used in SDN to direct traffic and exchange information between the middle and bottom layers.

A management and orchestration plan is also necessary to manage this infrastructure. It allows the configuration of the SDN controller and the initialisation of the “network elements”:

SDN controllers

The architecture of an SDN controller includes the following components:

  • The Northbound interface: It is not standardised and can take different forms. APIs using languages such as Java, Python, REST (Representational State Transfer) are most often available and allow applications to interact with the SDN network.
  • The Southbound interface: It is standardized and uses the OpenFlow protocol. Other protocols like SNMP, CLI can be implemented in “closed SDN” solutions.
  • Modules for managing network components (flow table, topology, a network element discovery module, an SDN network element management module, a table of usage statistics …etc.)

SDN leverages the usage of  “standardised” common off-the-shelf switches which are controlled by an SDN controller. This takes the computational complexity away from the SDN network devices, and makes them more “commoditised”, which is a synonym for lower costs.

The SDN Controller builds a global view of the network so that it can make decisions about routing flows from one point of the network to another. It communicates with applications (which will make requests to open and close flows) via APIs on its Northbound interface. It controls the network nodes (SDN devices) via its Southbound interface and the OpenFlow protocol.

One or many SDNs?

The concept of SDN has evolved from its original invention and has since seen several implementations depending on how the controller layer is connected to the SDN devices. There are four types of SDN which we can classify as follows :

  • Open SDN: Open SDN has a centralised control plane and uses OpenFlow for its southbound API. It requires evolutionary, hybrid deployment strategies to succeed. ONOS and BigSwitch are good examples of its implementation.
  • Overlay-based SDN: It operates on an overlay network and represents a practical solution to solve data centre connectivity issues, but doesn’t address physical networks underneath. As an example of this implementation, we’ll find: Juniper Contrail, NEC VTN and NSX (VMWare).
  • API-based SDN (or unopened SDN): The focus here is on network programming. It uses NetConf / OpFlex / SSH for southbound APIs to allow programming of network nodes including existing hardware infrastructure. OpenDaylight, APIC-DC,EM and Tail-f (NSO) are examples of its implementation.
  • Automation-based SDN (or hybrid SDN): It covers SDN-enabled as well as legacy networking equipment. One of its goals is to reduce the cost of network components. It uses automation tools (agents, Python, etc.) and generic white label components supporting several types of OS and leveraging ONIE (Open Network Install Environment)
The four SDN families

Among the widely deployed SDNs in the private cloud infrastructure arena, there is open source SDN as part of OpenStack, which supports the best of breed of overlay protocols such as GENEVE and VXLAN. Canonical’s Charmed Openstack uses Neutron to provide network connectivity between OpenStack instances, enabling multi-VM deployments. For this purpose, Neutron supports various software defined networking technologies, including Open Virtual Network (OVN), Open vSwitch (OVS), Juniper Contrail, Cisco ACI, etc. In addition to carrying the fundamentals of SDN, Charmed OpenStack is also integrated in the application’s larger automated deployment and life-cycle management ecosystem, provided by Juju.

SDN hasn’t stopped developing and there are many efforts and open source projects which work to address the ever evolving networking landscape, influenced by the ever changing application space and user expectations. The journey is certainly long but exciting to get to model-driven and why not self-healing networks. 

What is next?

In the next blog, we will give an overview of Software-Defined Data Centre, its main components and their integration approaches.

The next posts will cover:

Related posts


Benjamin Ryzman
21 June 2024

Data Centre AI evolution: combining MAAS and NVIDIA smart NICs

AI Article

It has been several years since Canonical committed to implementing support for NVIDIA smart NICs in our products. Among them, Canonical’s metal-as-a-service (MAAS) enables the management and control of smart NICs on top of bare-metal servers. NVIDIA BlueField smart NICs are very high data rate network interface cards providing advanced s ...


Tytus Kurek
21 August 2023

What is a hypervisor? A beginner’s guide

Cloud and server Article

In the realm of virtualisation and cloud computing, the hypervisor is a critical component that enables the seamless operation of multiple virtual machines (VMs) on a single host. While virtualisation is a technology, the hypervisor is its actual implementation. In this beginner’s guide, we will explore the fundamentals of hypervisors, th ...


Tytus Kurek
9 August 2023

What is virtualization? A beginner’s guide

Cloud and server Article

While information technology continues to evolve rapidly, virtualization remains a cornerstone of modern computing, enabling businesses to maximise resource utilisation, enhance flexibility, and reduce the total cost of ownership (TCO). It is a key building block of the cloud computing paradigm, and millions of organisations use it daily ...