Skip to content

Latest commit

 

History

History
35 lines (26 loc) · 2.16 KB

README.md

File metadata and controls

35 lines (26 loc) · 2.16 KB

Linux Async I/O API Benchmarks

Tests the relative performance of AIO APIs for Linux, specifically epoll and io_uring.

TODO

Language epoll io_uring
C [ ] [x]
Rust [x] [x]
Zig [x] [x]

Benchmark Results

System Specs:

  • Kernel: Linux 6.7.8-arch1-1
  • Distro: Arch Linux
  • CPU: AMD Ryzen 9 7950X
  • Memory: 2x 16GB DDR5 @ 6000MT/s

See k6/simple.js for k6 configuration

Api Language Median Req. Duration p(99) Req. Duration p(99.9) Req. Duration Req/s % More Requests
epoll Rust 2.81ms 3.68ms 5.86ms 160,689 Baseline
epoll Zig 2.81ms 3.66ms 5.91ms 160,753 +0.03%
io_uring Rust 2.23ms 2.95ms 5.97ms 198,728 +23.66%
io_uring Zig 2.22ms 2.93ms 5.96ms 198,933 +23.79%
io_uring C 2.22ms 2.90ms 6.05ms 199,793 +24.32%

Known issues

Benchmarks are run locally via k6. This isolates issues with networking components, but makes the system much more chatty. The kernel will need to spend more time shuttling packets across the loopback device. Additionally, the NIC is never touched. Until I have the hardware to separate the load generation to a new machine, this will continue to be the case.

Additionally, k6 is inefficient for this test. It's primarily an HTTP benchmarking tool, but we are effectively running TCP servers that send a fixed HTTP response. k6 will also use every core available, which increases the likelihood of impacting the TCP server thermally, with context switches, or via cache misses.

The data written as a response never changes, and thus does not represent a real world use-case. Instead, these benchmarks primarily aim to discover the relative overhead of the different APIs.