2 releases
0.1.1 | Aug 2, 2024 |
---|---|
0.1.0 | Aug 1, 2024 |
#901 in Concurrency
9KB
165 lines
Concurrent Queue Task Processing Library
This Rust library provides a robust solution for handling queue tasks in high concurrency scenarios. It ensures tasks are processed in order, enhancing service stability. Additionally, it allows configurable parallel task processing to optimize performance.
Features
- Queue-Based Task Management: Tasks are enqueued and processed sequentially.
- High Concurrency Handling: Designed for high-load environments to maintain stability.
- Configurable Parallel Processing: Set the number of tasks processed concurrently via parameters.
Installation
Add this to your Cargo.toml
:
[dependencies]
queued-task = "0.1.0"
Usage
use std::sync::Arc;
use std::time::Duration;
use queued_task::QueuedTaskBuilder;
#[tokio::test]
async fn test() {
// 10 queue_len, 2 process rate
let t = Arc::new(QueuedTaskBuilder::new(10, 2).handle(handle).build());
async fn handle(wait_time: Duration, c: usize) -> usize {
tokio::time::sleep(Duration::from_secs(1)).await;
println!("{} {}", c, wait_time.as_millis());
c
}
let mut ts = vec![];
for i in 0..20 {
let tt = t.clone();
ts.push(tokio::spawn(async move {
// push task
let state = tt.push(i).await.unwrap();
// waiting for task result
let result = state.wait_result().await;
dbg!(result);
}));
}
for x in ts {
let _ = x.await;
}
}
Dependencies
~2–7MB
~47K SLoC