Microsoft Using Linux in Azure Cloud Switch Platform
- By Kurt Mackie
- September 21, 2015
Microsoft raised eyebrows last week when it revealed that its new Azure Cloud Switch (ACS) datacenter operating system has a Linux core.
"The Azure Cloud Switch (ACS) is our foray into building our own software for running network devices like switches," explained Kamala Subramaniam, a principal architect for Azure Networking, in a Thursday blog post. "It is a cross-platform modular operating system for data center networking built on Linux."
ACS enables an application to "talk" to various application-specific integrated circuits (ASICs), according to Subramaniam. In addition, ACS can work with other application stacks, such as those built by Dell and Metaswitch. The Microsoft Research team first demonstrated ACS at SIGCOMM 2015 in August.
No Linux Distro
While ACS' software-defined networking capabilities may seem impressive, ACS' use of Linux seems to have flown under the radar screen.
Several news outlets last week claimed that Microsoft's use of Linux in ACS meant that the company now has its own Linux distro. However, when asked if that were true, a Microsoft spokesperson said, "No," that Microsoft doesn't have a Linux distro.
Essentially, Microsoft needed to solve a problem with hardware inflexibility. It wanted to take advantage of hardware technology improvements in ASICs but also wanted to be more agile and provide support for the software features it was rolling out in its Azure datacenters. To that end, Microsoft created ACS.
Despite its use of open source Linux, ACS was built mostly to support Microsoft's Azure datacenters. It has a C-based API, which allows developers to tap into it. For instance, various hardware switch manufacturers can interoperate with ACS via the API.
Subramaniam explained that ACS has a "lean stack," with just enough capabilities to support Microsoft's datacenter networks, but it also has a "modular stack." That combination of a lean and modular stack allows Microsoft to validate ACS faster and fix software flaws faster. ACS is capable of running Microsoft applications, as well as third-party ones, including open source apps, at the top of the stack (see diagram).
ACS is integrated with "Microsoft's monitoring and diagnostics system" for Azure. It allows switches to be managed via a graphical user interface, much like server patching.
"By deviating from the traditional enterprise interactive model of command line interfaces, it [ACS] allows for switches to be managed just as servers are with weekly software rollouts and roll backs thus ensuring a mature configuration and deployment model," Subramaniam wrote.
ACS isn't a commercial product right now, according to the Microsoft spokesperson, but Microsoft is showcasing it as a software-defined networking solution to the inflexibility of switch hardware.
"This is just internal right now," the spokesperson explained. "We are doing this because the approach of disaggregating the switch software from the switch hardware will continue to be a growing trend in the networking industry, and ACS is a Linux-based way to showcase our approach to this, which we're sharing with OCP [Open Compute Project]."
The SAI Spec
ACS is based on the Switch Abstraction Interface (SAI) specification overseen by the Open Compute Project. The Open Compute Project is an industry collaboration started by Facebook engineers that shares ideas and specifications to optimize datacenter designs.
Microsoft was "the initiator of SAI" last year according to Subramaniam, in a second blog post. Currently, it's is "a leading contributor" to SAI along with "Broadcom, Mellanox, Dell, Cavium, Barefoot, and Metaswitch." Subramaniam described SAI as "an ASIC agnostic interface."
The SAI spec was backed by both software and hardware makers. Microsoft, Dell and Metaswitch are the application stack providers that built upon the SAI spec. Barefoot, Broadcom, Cavium and Mellanox are the ASIC hardware makers that collaborated on it.
Kurt Mackie is senior news producer for the 1105 Enterprise Computing Group.