In 2017, Mozilla and others in the World Wide Web Consortium (W3C) released a new browser-based technology to enable high-performance applications on web pages. Initially based on Mozilla’s asm.js, this technology has evolved into the WebAssembly (WASM) that we know today. Not only has it been adopted by all the major browser systems, it is also being actively applied to other areas like cloud computing, embedded systems and gaming engines. This paper explores how this new technology can drive the engineering workloads of the coming years.
[siteorigin_widget class=”thinkup_builder_divider”][/siteorigin_widget]
A Short Introduction to WebAssembly
WebAssembly is a portable binary instruction format for a stack-based virtual machine that encodes as a low-level, assembly-like language. It serves as a compiler target for several languages, including statically-typed languages like C/C++, and is designed to enable near-native speed of execution on multiple platforms. It is considered to be hardware-agnostic, and can be compiled for multiple types of computing architectures and devices.
Operating as a bytecode representation of high-level languages that can be swiftly executed inside virtual machines (including those of the modern browsers), it is generally deployed to build high-performance applications on the web. The roots of WebAssembly primarily lie in asm.js, a compilation target from JavaScript. The objective was to build on top of the strong points of asm.js (e.g., AOT compilation), remove the deficiencies (e.g., slow compilation times, parsing challenges, etc.), and add new capabilities (e.g., compilation support for multiple languages, not just JavaScript.)
WebAssembly is designed for size-efficiency, faster-load-time, and near-native speed execution of portable bytecode on a wide range of operating systems and instruction set architectures. Based on open-standards, it generally offers backward web compatibility, and deploys memory-safe, secure execution environments within virtual machines. It is not meant to replace other languages (such as JavaScript) but to act more as a complementary technology.
An industry-wide collaboration, called the Bytecode Alliance has been established by leading companies like Amazon, Google, Intel, Microsoft, Mozilla, Siemens and others to build the standards and specifications, introduce new innovations, and develop the ecosystem around WebAssembly.
Why is WebAssembly Gaining Relevance?
JavaScript (JS) has been as the dominant programming language for web applications over the years. However, there are two primary limitations with this technology.
Firstly, JavaScript’s execution engine is inherently inefficient for building computationally-intensive web applications that need to operate at high speed, sometimes even in resource-constrained systems. Examples include 3D-gaming, advanced simulations, highly user-interactive websites and scientific modeling. This is where WebAssembly offers great value. Developers can improve application performance through WebAssembly JS APIs without the need to actually write WebAssembly code. This provides the needed support for compute-intensive workloads directly on the browser, and enables faster web application performance.
Secondly, a large number of mission critical applications have been developed in C/C++ over the past decades. With the evolution of technology and client requirements, there is an increasing need to migrate many of them to the web. However, transforming them to regular JavaScript-based web applications is not possible without significant re-architecture/re-write. This is where WebAssembly offers a great option. WASM modules can be compiled from existing C/C++ code, and run on the web with minimal efforts.
Furthermore, WebAssembly enables developers to compile code that are developed in several languages (including C#, Go, Kotlin, Rust and Swift), and then seamlessly run on different types of hardware systems, generally at near-native speeds. In general, WebAssembly enables high abstraction over hardware and separation of concerns, thus providing a robust mechanism for different data types to be mapped to the memory. As a result, a wide variety of object models can be implemented without the risk of incompatibility. This opens up a range of possibilities for this technology to be applied to even non-web applications.
Broadly speaking, WebAssembly offers three key advantages: compactness (comprises small binary files that are downloaded and deployed fast), portability (enables the bytecode to be easily ported from one system to another), and security (enables code to be securely deployed over web and non-web platforms.)
The Current State of Adoption
The global adoption of WebAssembly is, for the most part, at an exploration/experimental stage today, and will take a few years to get mainstreamed. Having said that, the range of use cases has been gradually increasing. Beyond the adoption by all the major browsers, Cloud and Edge Computing companies, such as AWS, Cloudfare, Envoy, Fastly and Netlify, have started offering WASM-supported function execution, and WASM extensions/plugins.
New compilers and toolchain libraries for WebAssembly are being developed. Key examples include Asterius, Binaryen, Emscripten and TinyGo. There is an increased focus on building WASM frameworks, the most popular being Microsoft’s Blazor client framework. Asm-dom (based on C++), Seed (based on Rust), Vecty and Vugu (both based on Go), and Yew (based on Rust) are among the top emerging ones. Then there are companies like Cosmonic and Suborbital that are building the entire application development frameworks on top of WASM runtimes.
Important use cases of WebAssembly include enabling Google Earth to run directly on any browser, pushing new updates of Amazon Prime Video to 8000+ device types, eBay’s web-based barcode scanning, Microsoft Flight Simulator, and others. Cloudfare workers, Krustlet (Kubernetes Kubelet in Rust), Open Policy Agent and Shopify Apps are some other popular examples.
Can WebAssembly Enable Next-Gen Engineering?
More than the conventional form, it is the evolving form of WebAssembly that excites the global developer community.
What started as a browser-based technology five years back is now a serious contender for building cloud, edge and server-side systems. For instance, consider the fact that not only does WebAssembly require lesser overheads (vis-à-vis running applications on virtual machines) but it is also container-compatible. Moreover, most of today’s processors are limited in terms of both computational power and energy efficiency – this necessitates more hardware acceleration support, and a greater focus on environmental costs. All these aspects make WebAssembly a great option for high-performance next-generation systems while maintaining lower carbon-footprint.
The Promise of Performance
WebAssembly offers a great option for resource-constrained systems due to its fast startup, less memory and storage needs, and near-native speed execution. As such, it is well-suited for IoT/embedded, edge and mobile workloads. As these domains gather further technological momentum, the role of WebAssembly will become more crucial. Database and analytics systems are other areas with a lot of possibilities. For instance, complex and long-running query execution plans can be compiled to WASM, and executed with lower latency and higher throughput than in conventional systems. WASM modules can serve as computation units within Linux processes, and execute at near-native speed, thus enabling fast serverless workloads. Similarly, heavy machine learning workloads, particularly those related to deep neural networks, can be executed with superior speed.
The Power of Heterogeneity & Interoperability
Certain technologies are expected to get a boost with WebAssembly. For instance, it is widely projected that most data processing will happen at the edge in the coming years. Unlike the Cloud, where the data center nodes tend to be homogeneous to a great extent, edge devices are built on different platforms and processor architectures. A major requirement for large-scale edge computing is the ability to run applications on every node in the same manner irrespective of the underlying architecture, platform or tech stack. WebAssembly is one of the best options to enable heterogeneity.
The WASM binaries can be executed on most computing architectures (e.g., ARM, MIPS, PowerPC, RISC-V, x86 and Xtensa) and hardware devices (Arduino, computers, smartphones, Raspberry Pi, etc.) Moreover, the WebAssembly System Interface (WASI) is emerging as a robust interface mechanism to enable WASM modules to seamlessly access external resources during runtime. As a result, the compiled WASM binaries can be efficiently executed both within and outside browsers, and across multiple platforms and operating systems.
The Trust of Security
A significant chunk of today’s software is built through external libraries, popular frameworks and 3rd party assets. This is generally done to build/release applications with minimal efforts, and within a short period of time. However, there is generally very little understanding of what happens ‘under-the-hood of the external software’. WebAssembly can be a great solution due to its intrinsic security model of safeguarding users from malicious modules, and providing developers the components needed to develop secure-by-default applications. Each WASM module executes within a sandboxed environment that is separated from the host runtimes. As a result, the compiled applications execute independently, and with limited non-determinism.
However, a lot of work is still needed.
WebAssembly is still evolving. It has come a long way in the past five years or so, but it is still early in its maturity cycle. The current tooling ecosystem around WebAssembly is quite basic. For instance, several compilers are available today to generate WASM binaries from multiple languages, but most of them are not fully integrated with the respective developer environments. Moreover, the core and embedder specifications, frameworks and several technical capabilities (e.g., garbage collection and multithreading) are either non-existing or work-in-progress.
Additionally, despite the fact that WebAssembly is executed in sandboxed environments, some security concerns still remain. For instance, certain vulnerabilities may not pose any real threat when compiled to native code, but lead to critical security issues when compiled to WebAssembly. More specifically, WASM binaries have sometimes been reported to be vulnerable to stack smashing attacks and memory protection issues. As a result, some WASM-compiled programs might keep running even while encountering unsafe behaviour, and this is dangerous for any software system. It has also been reported that many WASM binaries are developed in memory-unsafe languages, and hence, the application is prone to vulnerabilities that affect the source language.
Closing Comments
The benefits of WebAssembly are just beginning to show. It offers a mechanism for running all kinds of applications directly in the web, thus eliminating the need for application installs, and overriding the non-standard technical requirements of different systems. This factor can lead to easier, faster and greater adoption of digital systems, particularly in domains where technology adoption may be challenging.
Another possibility that has excited many is how this technology will transform the way cloud-native applications are built and deployed. Developers can write code in any preferred language, or use any PaaS infrastructure, and WASM runtimes will enable them to run securely at near-native speed on any platform – cloud, edge, mobile, on-premises, web or non-web. Apart from the application-centric benefits of fast performance, security and portability, this will also enable high developer productivity and improved talent management in an age where the net talent shortage is only expected to deepen.
Acknowledgement:
Security Risks of Porting C Programs to WebAssembly: Stiévenart, Roover & Ghafari (2021)
Understanding the Performance of WebAssembly Applications: Yan, Tu, Zhao, Zhou & Wang (2021)