Surreal Cloud beta is LIVE! Get started for free.

Why we are betting on Rust

Mar 13th, 2024

Why we are betting on Rust

by Alexander Fridriksson

SurrealDB has been built from the ground up to be the ultimate database for developers who want to build tomorrow’s applications.

In order to build the future of databases that can support the future of applications, we needed the future of low-level programming languages. We believe this language is Rust, which quite literally has allowed us to bring the future to our SQL-like query language SurrealQL, inspired by the Rust future.

Go slow to go fast

Front and centre on our home page, you’ll see these three sentences:

  • Develop easier.
  • Build faster.
  • Scale quicker.

This is not only what SurrealDB can do for your application, but what Rust does for SurrealDB. Due to Rust’s notoriously steep learning curve, develop easier and build faster might not be the first thing that comes to mind when you think of using Rust.

However, the ways Rust supports you to think differently, through using the borrow checker, lifetimes and more, pays compounding interest as your application starts achieving a phenomenal balance of safety and performance.

Yes, you may not be as fast going from 0 to 1 in Rust as in some other languages, but it’s easier than you think. This might however mean prototyping in a different language and then re-writing it in Rust once you see a long-term potential for the project. SurrealDB itself was first prototyped in Go and then entirely re-written in Rust.

The key point here is that once you pay the upfront cost of learning Rust, you can go further faster, or as is often said: go slow to go fast.

Now, before we go any further, we need to address the question I’m sure many of you will have: why not Zig or other newer languages?

While it’s true that you can build a database with Zig or other newer languages, they don’t have the features of Rust when it comes to memory safety by default while not having a garbage collector for the highest performance. However, there is one thing that stands out more than any feature difference.

Critical adoption

There is no denying that Rust has captured the hearts and minds of the developer community, having topped the chart as “the most admired programming language” in Stack Overflow’s annual developer survey for 8 years in a row. Far from being just admired, it’s also one of the fastest-growing languages on GitHub.

Rust has even achieved adoption where no other language aside from C has been, not even C++, namely the Linux kernel.

This begs the question, why?

As Software Engineer Wedson Almeida Filho said

We feel that Rust is now ready to join C as a practical language for implementing the kernel. It can help us reduce the number of potential bugs and security vulnerabilities in privileged code while playing nicely with the core kernel and preserving its performance characteristics.

To put this into perspective, a talk at the 2019 Linux Security Summit showed that memory safety issues are estimated to account for 65-88% of security vulnerabilities in major systems, including Android and Ubuntu.

This also aligns with Microsoft’s experience

~70% of the vulnerabilities Microsoft assigns a CVE each year continue to be memory safety issues

This goes to show how even after decades of development from some of the best engineers using C and C++ best practices, issues such as accessing memory that has already been freed, data races, and other problems still persist. Therefore it’s hard to claim it’s just skill issues, but rather more likely fundamental issues with the languages being used.

With this context in mind, you can see why Microsoft Azure CTO Mark Russinovich said

Speaking of languages, it’s time to halt starting any new projects in C/C++ and use Rust for those scenarios where a non-GC language is required. For the sake of security and reliability. the industry should declare those languages as deprecated.

This trust in Rust does not come from nowhere, there has been a tremendous amount of work put into making Rust fully usable in safety-critical environments. This can be seen in Rust’s recent qualification under the ISO 26262 and IEC 61508 standards through the Ferrocene toolchain developed by Ferrous Systems.

You might have also heard that governments are taking notice of these developments, such as the US White House Office of the National Cyber Director (ONCD). This office issued a report last month (February 2024) recommending a move to memory-safe programming languages and pointing to Rust as an example of a potential replacement for C and C++ in safety-critical space systems.

It’s not rocket science

While databases are not life-critical space systems, they often play a life-critical role in organisations. You want to keep your data safe and secure because if you lose your data, you can lose your business.

Therefore if between 65-88% of security vulnerabilities in major systems can be caused by memory issues, it’s not rocket science to understand why we are betting on Rust to keep your data as safe as possible.

At SurrealDB we are passionate about building the future we want to see in the world.

If you want to be a part of building this future, you can join our exceptional team of Rust engineers and contribute to shaping the future of SurrealDB.

If you want to be a part of experiencing this future, get started with SurrealDB.

Part of the change we want to see in the world is making Rust more accessible, which is why we started the Women in Rust meet-up, where women can come together to learn and build skills in Rust!