pub struct GroupcacheBuilder<Value: ValueBounds> { /* private fields */ }
Expand description

Allows to build groupcache instance with customized caches, timeouts etc

Implementations§

source§

impl<Value: ValueBounds> GroupcacheBuilder<Value>

source

pub fn main_cache(self, main_cache: Cache<String, Value>) -> Self

Sets main_cache for groupcache.

main_cache is the cache for items that this peer is the owner of. There is one owner of a given key in a set of peers forming hash ring and this peer stores values in main_cache.

By default, moka cache is used and this setter allows to customize this cache (eviction policy, size etc.)

source

pub fn hot_cache(self, hot_cache: Cache<String, Value>) -> Self

Sets hot_cache for groupcache.

The hot_cache is the cache for items that seem popular enough to replicate to this node, even though it’s not the owner. This however may lead to inconsistencies when expiring values (see Groupcache::remove).

By default, hot_cache stores up to 10k items and expires after 30s. Depending on use_case you may either disable hot_cache or tweak time_to_live.

source

pub fn https(self) -> Self

When connecting to peers, use https instead of http.

Note that this requires you to configure server running Groupcache::grpc_service to handle TLS. Look into tonic/axum documentation how to do so.

By default, http is used.

source

pub fn grpc_endpoint_builder( self, builder: impl Fn(Endpoint) -> Endpoint + Send + Sync + 'static ) -> Self

Allows to customize HTTP/2 channels for peer-to-peer connections.

By default, request timeout is set to 10 seconds.

source

pub fn service_discovery( self, service_discovery: impl ServiceDiscovery + 'static ) -> Self

Enable automatic pull-based service discovery via ServiceDiscovery

By default, automatic service is disabled, useful when: - deployed on kubernetes (see examples) - registered in consul etc

source

pub fn build(self) -> Groupcache<Value>

Auto Trait Implementations§

§

impl<Value> !RefUnwindSafe for GroupcacheBuilder<Value>

§

impl<Value> Send for GroupcacheBuilder<Value>

§

impl<Value> !Sync for GroupcacheBuilder<Value>

§

impl<Value> Unpin for GroupcacheBuilder<Value>
where Value: Unpin,

§

impl<Value> !UnwindSafe for GroupcacheBuilder<Value>

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> 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> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

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

§

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>,

§

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<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

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