RedisEnterpriseTemplate

Struct RedisEnterpriseTemplate 

Source
pub struct RedisEnterpriseTemplate { /* private fields */ }
Expand description

Redis Enterprise template for production-grade deployments

Implementations§

Source§

impl RedisEnterpriseTemplate

Source

pub fn new(name: impl Into<String>) -> Self

Create a new Redis Enterprise template

Source

pub fn cluster_name(self, name: impl Into<String>) -> Self

Set the cluster name

Source

pub fn admin_username(self, username: impl Into<String>) -> Self

Set the admin username (email format required)

Source

pub fn admin_password(self, password: impl Into<String>) -> Self

Set the admin password (must be strong)

Source

pub fn accept_eula(self) -> Self

Accept the End User License Agreement

Source

pub fn license_file(self, path: impl Into<String>) -> Self

Set a license file path

Source

pub fn ui_port(self, port: u16) -> Self

Set the UI port (default: 8443)

Source

pub fn api_port(self, port: u16) -> Self

Set the API port (default: 9443)

Source

pub fn database_port_start(self, port: u16) -> Self

Set the starting port for database endpoints (default: 12000)

Source

pub fn persistent_path(self, path: impl Into<String>) -> Self

Set custom persistent storage path

Source

pub fn ephemeral_path(self, path: impl Into<String>) -> Self

Set custom ephemeral storage path

Source

pub fn memory_limit(self, limit: impl Into<String>) -> Self

Set memory limit for the container

Source

pub fn with_database(self, name: impl Into<String>) -> Self

Create an initial database after cluster setup

Source

pub fn custom_image( self, image: impl Into<String>, tag: impl Into<String>, ) -> Self

Use a custom Redis Enterprise image and tag

§Example
let template = RedisEnterpriseTemplate::new("my-redis")
    .custom_image("my-registry/redis-enterprise", "latest")
    .platform("linux/arm64")
    .accept_eula();
Source

pub fn platform(self, platform: impl Into<String>) -> Self

Set the platform for the container (e.g., “linux/arm64”, “linux/amd64”)

This is especially useful for ARM-based Redis Enterprise images on Apple Silicon Macs or ARM servers.

Source

pub fn bootstrap_timeout(self, timeout: Duration) -> Self

Set the bootstrap timeout (default: 60 seconds)

Source

pub fn bootstrap_retries(self, retries: u32) -> Self

Set the number of bootstrap retries (default: 3)

Source

pub fn api_ready_timeout(self, timeout: Duration) -> Self

Set the API ready timeout (default: 30 seconds)

Source

pub async fn start(self) -> Result<RedisEnterpriseConnectionInfo, Error>

Start the Redis Enterprise container and initialize the cluster

§Errors

Returns an error if:

  • EULA is not accepted
  • Container fails to start
  • Cluster initialization fails
  • API is not accessible

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> 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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. 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
Source§

impl<T> ErasedDestructor for T
where T: 'static,