#prometheus #async-channel #metrics #tokio #channel

tokio-prometheus-metered-channel

Metered tokio channels with Prometheus metrics integration

1 unstable release

0.1.0 Nov 29, 2024

#956 in Concurrency

Apache-2.0

38KB
752 lines

Tokio Prometheus metered channel

Add the following to your Cargo.toml:

tokio-prometheus-metered-channel = "0.1.0"

Metered Bounded Channel

The metered bounded channel is a specialized threading utility designed to handle communication between threads with an upper limit on capacity while tracking the channel's occupancy through Prometheus metrics.

Functionality

  • Bounded Capacity: This channel ensures that no more than a predefined number of messages are held in the channel at any given time.
  • Backpressure Handling: When the channel reaches its capacity, any additional attempts to send messages will be blocked, allowing for backpressure management until the channel has available space.
  • Prometheus Integration: The current occupancy of the channel is exposed as a Prometheus metric, enabling real-time monitoring of how "full" the channel is.

Dependencies

~10–23MB
~316K SLoC