36 releases

0.11.0 Aug 16, 2023
0.10.14 Jul 21, 2022
0.10.13 Jun 10, 2022
0.10.12 Mar 10, 2022
0.2.0 Jul 31, 2019

#6 in Concurrency

Download history 590573/week @ 2024-05-18 559775/week @ 2024-05-25 632666/week @ 2024-06-01 614932/week @ 2024-06-08 580660/week @ 2024-06-15 566228/week @ 2024-06-22 551880/week @ 2024-06-29 611916/week @ 2024-07-06 613275/week @ 2024-07-13 648760/week @ 2024-07-20 636633/week @ 2024-07-27 623289/week @ 2024-08-03 708523/week @ 2024-08-10 712252/week @ 2024-08-17 712765/week @ 2024-08-24 540367/week @ 2024-08-31

2,779,961 downloads per month
Used in 1,923 crates (450 directly)

Apache-2.0/MIT

77KB
1.5K SLoC

Flume

A blazingly fast multi-producer, multi-consumer channel.

Cargo Documentation License actions-badge

use std::thread;

fn main() {
    println!("Hello, world!");

    let (tx, rx) = flume::unbounded();

    thread::spawn(move || {
        (0..10).for_each(|i| {
            tx.send(i).unwrap();
        })
    });

    let received: u32 = rx.iter().sum();

    assert_eq!((0..10).sum::<u32>(), received);
}

Why Flume?

  • Featureful: Unbounded, bounded and rendezvous queues
  • Fast: Always faster than std::sync::mpsc and sometimes crossbeam-channel
  • Safe: No unsafe code anywhere in the codebase!
  • Flexible: Sender and Receiver both implement Send + Sync + Clone
  • Familiar: Drop-in replacement for std::sync::mpsc
  • Capable: Additional features like MPMC support and send timeouts/deadlines
  • Simple: Few dependencies, minimal codebase, fast to compile
  • Asynchronous: async support, including mix 'n match with sync code
  • Ergonomic: Powerful select-like interface

Usage

To use Flume, place the following line under the [dependencies] section in your Cargo.toml:

flume = "x.y"

Cargo Features

Flume comes with several optional features:

  • spin: use spinlocks instead of OS-level synchronisation primitives internally for some kind of data access (may be more performant on a small number of platforms for specific workloads)

  • select: Adds support for the Selector API, allowing a thread to wait on several channels/operations at once

  • async: Adds support for the async API, including on otherwise synchronous channels

  • eventual-fairness: Use randomness in the implementation of Selector to avoid biasing/saturating certain events over others

You can enable these features by changing the dependency in your Cargo.toml like so:

flume = { version = "x.y", default-features = false, features = ["async", "select"] }

Benchmarks

Although Flume has its own extensive benchmarks, don't take it from here that Flume is quick. The following graph is from the crossbeam-channel benchmark suite.

Tests were performed on an AMD Ryzen 7 3700x with 8/16 cores running Linux kernel 5.11.2 with the bfq scheduler.

Flume benchmarks (crossbeam benchmark suite)

License

Flume is licensed under either of:

Dependencies

~135–530KB