Skip to content

Latest commit

 

History

History
37 lines (28 loc) · 1.56 KB

README.md

File metadata and controls

37 lines (28 loc) · 1.56 KB

conflation

A set of thread-safe channels in Rust that conflates submitted items via sender-supplied keys.

Overview

A conflating queue is generally useful when two conditions are met:

  1. A producer is enqueueing items at a faster rate than a slower consumer can dequeue them.
  2. It is acceptable to drop in-flight messages by retaining only the most recently produced message along some (key) boundary.

This channel does not offer the strong guarantee that a replacement will always occur if a new keyed entry is inserted into the channel and an unread duplicate is already present. The duplicate may or may not be dropped at some indeterminate point in the future, generally to keep the queue under a specific maximum compaction ratio.

Usage

The semantics of these channels are identical to standard Senders and Receivers, only that a key is required to be specified upon submission. The key and value are returned by the receiver.

use conflation::unbounded;

let (tx, rx) = unbounded();
// Both messages are tagged with key = 1
let tx_result1 = tx.send(1, "foo".to_owned()).unwrap();
let tx_result2 = tx.send(1, "bar".to_owned()).unwrap();
// The receiver will only yield (1, "bar") as (1, "foo") was
// conflated by the producer.
let (key, value) = rx.recv().unwrap();

Unlike std::sync::mpsc channels, conflation::sync::mpmc channels are multi-producer and multi-consumer. If multiple receivers are used, then this channel will function identically to a work-sharing queue, only that work submitted with the same key can potentially be conflated in transit.