pub struct ConnectionPool {
MaxConnections: usize,
ConnectionTimeout: Duration,
Semaphore: Arc<Semaphore>,
ActiveConnections: Arc<Mutex<HashMap<String, ConnectionHandle>>>,
HealthChecker: Arc<Mutex<ConnectionHealthChecker>>,
}Expand description
Connection pool for IPC operations - manages concurrent connections efficiently
Purpose: Prevents connection exhaustion by pooling connections and reusing them Features: Health monitoring, automatic cleanup, configurable timeouts
Fields§
§MaxConnections: usize§ConnectionTimeout: Duration§Semaphore: Arc<Semaphore>§ActiveConnections: Arc<Mutex<HashMap<String, ConnectionHandle>>>§HealthChecker: Arc<Mutex<ConnectionHealthChecker>>Implementations§
Source§impl ConnectionPool
impl ConnectionPool
Sourcepub fn new(MaxConnections: usize, ConnectionTimeout: Duration) -> Self
pub fn new(MaxConnections: usize, ConnectionTimeout: Duration) -> Self
Create a new connection pool with specified parameters
Sourcepub async fn GetConnection(&self) -> Result<ConnectionHandle, String>
pub async fn GetConnection(&self) -> Result<ConnectionHandle, String>
Get a connection handle from the pool with timeout
Sourcepub async fn ReleaseConnection(&self, handle: ConnectionHandle)
pub async fn ReleaseConnection(&self, handle: ConnectionHandle)
Release a connection handle back to the pool
Sourcepub async fn GetStats(&self) -> ConnectionStats
pub async fn GetStats(&self) -> ConnectionStats
Get connection statistics for monitoring
Sourcepub async fn CleanUpStaleConnections(&self) -> usize
pub async fn CleanUpStaleConnections(&self) -> usize
Clean up stale connections
Sourceasync fn StartHealthMonitoring(&self, connection_id: &str)
async fn StartHealthMonitoring(&self, connection_id: &str)
Start health monitoring for a connection
Auto Trait Implementations§
impl Freeze for ConnectionPool
impl !RefUnwindSafe for ConnectionPool
impl Send for ConnectionPool
impl Sync for ConnectionPool
impl Unpin for ConnectionPool
impl !UnwindSafe for ConnectionPool
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
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].