pub struct LeaseLooper<T, Fut, S>where
T: Fn(LeaseContext, S) -> Fut + Send + Sync + Clone + 'static,
Fut: Future<Output = Result<(), Box<dyn Error + Send + Sync>>> + Send + 'static,
S: Clone + Send + Sync + 'static,{ /* private fields */ }Expand description
A lease-based looper that ensures only one worker can execute a task at a time across multiple processes/machines using PostgreSQL as the coordination mechanism.
The looper function receives shared state of type S, allowing you to pass
application-specific data (similar to Axum’s state handling).
§Example
ⓘ
use std::sync::Arc;
use tokio::sync::Mutex;
use pg_lease::{LeaseLooper, LeaseLooperOptions};
#[derive(Clone)]
struct AppState {
counter: Arc<Mutex<i32>>,
config: String,
}
let state = AppState {
counter: Arc::new(Mutex::new(0)),
config: "production".to_string(),
};
let looper_func = |state: AppState| async move {
let mut counter = state.counter.lock().await;
*counter += 1;
println!("Counter: {}, Config: {}", *counter, state.config);
Ok(())
};
let looper = LeaseLooper::new(
"my-task".to_string(),
looper_func,
"worker-1".to_string(),
pool,
LeaseLooperOptions::default(),
state,
);Implementations§
Source§impl<T, Fut, S> LeaseLooper<T, Fut, S>
impl<T, Fut, S> LeaseLooper<T, Fut, S>
pub fn new( lease_name: String, looper_func: T, worker_id: String, pool: Pool<Postgres>, options: LeaseLooperOptions, state: S, ) -> Self
Auto Trait Implementations§
impl<T, Fut, S> Freeze for LeaseLooper<T, Fut, S>
impl<T, Fut, S> !RefUnwindSafe for LeaseLooper<T, Fut, S>
impl<T, Fut, S> Send for LeaseLooper<T, Fut, S>
impl<T, Fut, S> Sync for LeaseLooper<T, Fut, S>
impl<T, Fut, S> Unpin for LeaseLooper<T, Fut, S>
impl<T, Fut, S> UnsafeUnpin for LeaseLooper<T, Fut, S>where
T: UnsafeUnpin,
S: UnsafeUnpin,
impl<T, Fut, S> !UnwindSafe for LeaseLooper<T, Fut, S>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more