Unikernels

What are Unikernels?

Unikernels are specialized, single-purpose machine images that contain only the necessary operating system components to run a specific application. They offer improved security and performance due to their minimal attack surface and reduced overhead. In cloud environments, Unikernels can provide lightweight, fast-booting alternatives to traditional virtual machines for certain types of applications.

Unikernels are a novel approach to deploying cloud services, where the application and the operating system are tightly integrated and run as a single process on a hypervisor. This approach has significant implications for security, performance, and manageability of cloud services.

Unikernels represent a significant departure from the traditional model of deploying services on a full-stack operating system, such as Linux or Windows. Instead of running multiple processes on a shared operating system, each unikernel application runs in its own isolated environment, with no other processes or users.

Definition of Unikernels

A unikernel is a specialized, single-address-space machine image constructed by using library operating systems. A library operating system is an operating system that provides the same interfaces as a traditional operating system, but is a library that applications link against. This allows the application to be more tightly integrated with the operating system and to use only the operating system functionality it needs.

Unikernels are typically constructed by statically linking the application and the necessary operating system libraries together into a single binary. This binary is then run directly on a hypervisor or bare metal, without the need for a traditional operating system.

Library Operating Systems

Library operating systems are a key component of unikernels. They provide the interfaces and services that applications need to run, such as networking, file systems, and device drivers. However, unlike a traditional operating system, these services are provided as libraries that the application links against, rather than as separate processes or kernel modules.

This approach has several advantages. It allows the application to use only the services it needs, reducing the size and complexity of the resulting unikernel. It also allows the application to be more tightly integrated with the operating system, potentially improving performance and security.

Single-Address-Space Machines

Unikernels are single-address-space machines, meaning that the application and the operating system share the same memory address space. This is in contrast to traditional operating systems, which use separate address spaces for the kernel and each user process.

Sharing the same address space has several advantages. It simplifies the design of the operating system, as there is no need for complex memory management or protection mechanisms. It also allows for more efficient communication between the application and the operating system, as there is no need to switch contexts or copy data between different address spaces.

History of Unikernels

The concept of unikernels has its roots in the research on exokernels and library operating systems that was conducted at MIT in the 1990s. The goal of this research was to develop a new kind of operating system that would give applications more control over the hardware and eliminate the overhead of traditional operating systems.

The first practical implementation of these ideas was the Nemesis operating system, developed at the University of Cambridge. Nemesis was a single-address-space operating system that provided its services as libraries that applications could link against. However, Nemesis was not a true unikernel, as it still required a separate kernel to manage the hardware.

Development of MirageOS

The term "unikernel" was first used in the context of the MirageOS project, which started at the University of Cambridge in 2010. MirageOS is a library operating system that targets the Xen hypervisor, allowing applications to be compiled directly into Xen virtual machines.

The development of MirageOS was driven by the need for more secure and efficient cloud services. By eliminating the traditional operating system and running each application in its own virtual machine, MirageOS aimed to reduce the attack surface and improve the performance of cloud services.

Other Unikernel Systems

Since the development of MirageOS, several other unikernel systems have been developed. These include HalVM, OSv, and IncludeOS. Each of these systems has its own strengths and weaknesses, and they target different use cases and environments.

For example, HalVM is a Haskell-based unikernel system that targets the Xen hypervisor, while OSv is a general-purpose unikernel system that can run existing Linux applications. IncludeOS, on the other hand, is a minimalistic unikernel system designed for high-performance network applications.

Use Cases for Unikernels

Unikernels are particularly well-suited for cloud computing environments, where they can provide significant benefits in terms of security, performance, and resource usage. By running each application in its own isolated environment, unikernels can reduce the attack surface and improve the security of cloud services.

Unikernels can also improve the performance of cloud services, as they eliminate the overhead of traditional operating systems and allow applications to run directly on the hypervisor. This can result in lower latency and higher throughput, especially for I/O-intensive applications.

Security Applications

One of the main use cases for unikernels is in security-sensitive applications. By eliminating the traditional operating system and running each application in its own isolated environment, unikernels can significantly reduce the attack surface. This makes it much harder for attackers to exploit vulnerabilities and gain access to the system.

Unikernels also provide strong isolation between applications, as each application runs in its own virtual machine. This prevents one compromised application from affecting other applications on the same system.

Edge Computing

Unikernels are also well-suited for edge computing, where resources are often limited and efficiency is paramount. Because unikernels are small and lightweight, they can run on low-power devices and use less bandwidth than traditional operating systems.

Furthermore, unikernels can be started and stopped quickly, making them ideal for situations where services need to be dynamically deployed and scaled. This makes unikernels a good fit for edge computing applications, such as IoT devices and mobile applications.

Examples of Unikernels

There are several examples of unikernels being used in real-world applications. These examples demonstrate the potential benefits of unikernels, as well as some of the challenges associated with their use.

One example is the use of MirageOS to implement a secure, high-performance DNS server. By using a unikernel, the developers were able to reduce the size of the DNS server by over 90%, while also improving its performance and security.

MirageOS DNS Server

The MirageOS DNS server is a good example of the potential benefits of unikernels. By using a unikernel, the developers were able to significantly reduce the size of the DNS server, from over 10 MB to less than 1 MB. This reduction in size not only saves resources, but also reduces the attack surface, making the DNS server more secure.

In addition to reducing the size, the use of a unikernel also improved the performance of the DNS server. Because the DNS server runs directly on the hypervisor, it can handle requests more quickly and efficiently than a traditional DNS server running on a full-stack operating system.

HalVM Network Router

Another example of a unikernel in action is the HalVM network router. This router is implemented as a unikernel, allowing it to run directly on the hypervisor and handle network packets more efficiently than a traditional router.

The HalVM router demonstrates the potential of unikernels for network-intensive applications. By eliminating the overhead of a traditional operating system, the HalVM router can handle more packets per second and achieve lower latency than a traditional router.

Challenges and Limitations of Unikernels

While unikernels offer many potential benefits, they also come with their own set of challenges and limitations. These include issues related to debugging, compatibility, and manageability.

Debugging unikernels can be challenging, as they lack many of the tools and interfaces that developers are used to. Because unikernels run directly on the hypervisor, there is no traditional operating system to provide debugging facilities. This can make it difficult to diagnose and fix problems when they occur.

Compatibility Issues

Another challenge with unikernels is compatibility. Because unikernels are a departure from the traditional model of running applications on a full-stack operating system, they may not be compatible with existing applications and tools. This can make it difficult to port existing applications to unikernels, and may require significant changes to the application code.

Furthermore, because each unikernel system provides its own set of libraries and interfaces, there may be compatibility issues between different unikernel systems. This can make it difficult to move applications between different unikernel systems, and may require changes to the application code.

Manageability Challenges

Manageability is another challenge with unikernels. Because each unikernel runs in its own isolated environment, it can be difficult to manage large numbers of unikernels. Traditional management tools and practices may not work with unikernels, and new tools and practices may need to be developed.

In addition, because unikernels are single-address-space machines, they lack the process isolation and user management features of traditional operating systems. This can make it difficult to manage multi-user environments and to isolate different parts of an application.

Conclusion

Unikernels represent a novel approach to deploying cloud services, with potential benefits in terms of security, performance, and resource usage. However, they also come with their own set of challenges and limitations, and may not be suitable for all applications and environments.

Despite these challenges, unikernels are an active area of research and development, and they are likely to play an important role in the future of cloud computing. As the technology matures and the ecosystem develops, we can expect to see more and more applications taking advantage of the unique benefits that unikernels offer.

Join other high-impact Eng teams using Graph
Ready to join the revolution?
Join other high-impact Eng teams using Graph
Ready to join the revolution?

Build more, chase less

Add to Slack