Async Rust is about concurrency, not (just) performance

submited by
Style Pass
2025-01-15 15:00:08

TLDR: I think that the primary benefit of async/await is that it lets us concisely express complex concurrency; any (potential) performance improvements are just a second-order effect. We should thus judge async primarily based on how it simplifies our code, not how (or if) it makes the code faster.

While teaching a Rust course at my university, I showed my students various ways to implement networking applications, from blocking I/O with threads, non-blocking I/O with manual state machines and ultimately async/await. When I was explaining the motivation for async Rust, I was reminded of a pet peeve of mine related to the way it is sometimes being discussed online, where performance is being used as the main motivation when async Rust is being promoted, which in turn provokes critical responses that claim that the performance effect is probably not worth the problems associated with async. I think that this view is incomplete; to me, the primary motivation to use async is almost never performance (alone), but rather the ability to elegantly express and compose concurrent processes, which I consider to be the true killer feature of the async/await mechanism. I repeatedly tried to express this sentiment in comments on Reddit and Twitter, so I thought that I should finally write it down so that I can refer to it in the future.

In this post, I’ll try to explore different motivations for using async, show a few examples where I appreciate the benefits that async gives us, and examine some proposed alternatives and why I don’t think that they are viable for the use-cases that I usually need to solve. This is all interspersed by an assorted collection of my opinions on async, which is why it is a bit rambly – you have been warned :)

Leave a Comment