CrossClusterReplicationConfig

Struct CrossClusterReplicationConfig 

Source
#[non_exhaustive]
pub struct CrossClusterReplicationConfig { pub cluster_role: ClusterRole, pub primary_cluster: Option<RemoteCluster>, pub secondary_clusters: Vec<RemoteCluster>, pub update_time: Option<Timestamp>, pub membership: Option<Membership>, /* private fields */ }
Expand description

Cross cluster replication config.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§cluster_role: ClusterRole

The role of the cluster in cross cluster replication.

§primary_cluster: Option<RemoteCluster>

Details of the primary cluster that is used as the replication source for this secondary cluster.

This field is only set for a secondary cluster.

§secondary_clusters: Vec<RemoteCluster>

List of secondary clusters that are replicating from this primary cluster.

This field is only set for a primary cluster.

§update_time: Option<Timestamp>

Output only. The last time cross cluster replication config was updated.

§membership: Option<Membership>

Output only. An output only view of all the member clusters participating in the cross cluster replication. This view will be provided by every member cluster irrespective of its cluster role(primary or secondary).

A primary cluster can provide information about all the secondary clusters replicating from it. However, a secondary cluster only knows about the primary cluster from which it is replicating. However, for scenarios, where the primary cluster is unavailable(e.g. regional outage), a GetCluster request can be sent to any other member cluster and this field will list all the member clusters participating in cross cluster replication.

Implementations§

Source§

impl CrossClusterReplicationConfig

Source

pub fn new() -> Self

Source

pub fn set_cluster_role<T: Into<ClusterRole>>(self, v: T) -> Self

Sets the value of cluster_role.

Source

pub fn set_primary_cluster<T>(self, v: T) -> Self
where T: Into<RemoteCluster>,

Sets the value of primary_cluster.

Source

pub fn set_or_clear_primary_cluster<T>(self, v: Option<T>) -> Self
where T: Into<RemoteCluster>,

Sets or clears the value of primary_cluster.

Source

pub fn set_secondary_clusters<T, V>(self, v: T) -> Self
where T: IntoIterator<Item = V>, V: Into<RemoteCluster>,

Sets the value of secondary_clusters.

Source

pub fn set_update_time<T>(self, v: T) -> Self
where T: Into<Timestamp>,

Sets the value of update_time.

Source

pub fn set_or_clear_update_time<T>(self, v: Option<T>) -> Self
where T: Into<Timestamp>,

Sets or clears the value of update_time.

Source

pub fn set_membership<T>(self, v: T) -> Self
where T: Into<Membership>,

Sets the value of membership.

Source

pub fn set_or_clear_membership<T>(self, v: Option<T>) -> Self
where T: Into<Membership>,

Sets or clears the value of membership.

Trait Implementations§

Source§

impl Clone for CrossClusterReplicationConfig

Source§

fn clone(&self) -> CrossClusterReplicationConfig

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 Debug for CrossClusterReplicationConfig

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for CrossClusterReplicationConfig

Source§

fn default() -> CrossClusterReplicationConfig

Returns the “default value” for a type. Read more
Source§

impl Message for CrossClusterReplicationConfig

Source§

fn typename() -> &'static str

The typename of this message.
Source§

impl PartialEq for CrossClusterReplicationConfig

Source§

fn eq(&self, other: &CrossClusterReplicationConfig) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for CrossClusterReplicationConfig

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> 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> 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<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
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,