ConnectionManager

Struct ConnectionManager 

Source
pub struct ConnectionManager<T: ClientFormat> { /* private fields */ }
Expand description

ConnectionManager is the underlying manager that bb8::Pool uses to manage connections.

Implementations§

Source§

impl<T: ClientFormat> ConnectionManager<T>

Source

pub async fn try_new<A: Into<Destination>, S: Into<Settings>>( destination: A, options: ClientOptions, settings: Option<S>, span: Option<NonZeroU64>, ) -> Result<Self>

Creates a new connection manager for the pool.

This method builds a ConnectionManager that the pool will use to create and manage connections to ClickHouse. Each connection will be built using the provided destination, options, and settings.

§Arguments
  • destination - The ClickHouse server address (host:port or socket address)
  • options - Client configuration options
  • settings - Optional ClickHouse settings to apply to all connections
  • span - Optional tracing span ID for distributed tracing
§Errors

Returns an error if the destination cannot be resolved or is invalid

Source

pub async fn try_new_with_builder(builder: ClientBuilder) -> Result<Self>

Creates a new connection manager from an existing ClientBuilder.

This is an alternative constructor that allows you to pre-configure a ClientBuilder with custom settings before creating the connection manager. This is useful when you need fine-grained control over the client configuration.

Unlike Self::try_new, which creates a ClientBuilder internally, this method accepts a pre-configured builder directly.

§Errors

Returns an error if the builder’s destination cannot be verified

Source

pub fn with_check(self, check: bool) -> Self

Whether the underlying connection will issue a ping when checking health.

Source

pub fn connection_identifier(&self) -> String

Useful to determine if 2 connections are essentially the same

Trait Implementations§

Source§

impl<T: Clone + ClientFormat> Clone for ConnectionManager<T>

Source§

fn clone(&self) -> ConnectionManager<T>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: ClientFormat> ManageConnection for ConnectionManager<T>

Source§

type Connection = Client<T>

The connection type this manager deals with.
Source§

type Error = Error

The error type returned by Connections.
Source§

async fn connect(&self) -> Result<Self::Connection, Self::Error>

Attempts to create a new connection.
Source§

async fn is_valid(&self, conn: &mut Self::Connection) -> Result<(), Self::Error>

Determines if the connection is still connected to the database.
Source§

fn has_broken(&self, conn: &mut Self::Connection) -> bool

Synchronously determine if the connection is no longer usable, if possible.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more