pub struct Cluster<T> { /* private fields */ }
Expand description
The data structure responsible for maintaining consensus per-transaction across the network.
Implementations§
source§impl<T> Cluster<T>
impl<T> Cluster<T>
source§impl<T> Cluster<T>
impl<T> Cluster<T>
sourcepub async fn mutate(&self, txn: &Txn, participant: Link) -> TCResult<()>
pub async fn mutate(&self, txn: &Txn, participant: Link) -> TCResult<()>
Register a participant in the given Txn
.
sourcepub async fn lead_and_distribute_commit(&self, txn: Txn) -> TCResult<()>
pub async fn lead_and_distribute_commit(&self, txn: Txn) -> TCResult<()>
Claim leadership of this Txn
, then commit all replicas.
sourcepub async fn distribute_commit(&self, txn: &Txn) -> TCResult<()>
pub async fn distribute_commit(&self, txn: &Txn) -> TCResult<()>
Commit the given Txn
for all members of this Cluster
.
sourcepub async fn distribute_rollback(&self, txn: &Txn)
pub async fn distribute_rollback(&self, txn: &Txn)
Roll back the given Txn
for all members of this Cluster
.
source§impl<T> Cluster<T>
impl<T> Cluster<T>
sourcepub async fn replicas(
&self,
txn_id: TxnId
) -> TCResult<impl Deref<Target = BTreeSet<Host>>>
pub async fn replicas( &self, txn_id: TxnId ) -> TCResult<impl Deref<Target = BTreeSet<Host>>>
Get the set of current replicas of this Cluster
.
sourcepub async fn add_replica(&self, txn: &Txn, replica: Host) -> TCResult<bool>
pub async fn add_replica(&self, txn: &Txn, replica: Host) -> TCResult<bool>
Add a replica to this Cluster
.
Returns true
if a new replica was added.
sourcepub async fn lead_and_add_replica(&self, txn: Txn) -> TCResult<bool>
pub async fn lead_and_add_replica(&self, txn: Txn) -> TCResult<bool>
Claim leadership of the given Txn
and add a replica to this Cluster
.
sourcepub async fn remove_replicas<'a, R: IntoIterator<Item = &'a Host>>(
&'a self,
txn_id: TxnId,
to_remove: R
) -> TCResult<()>
pub async fn remove_replicas<'a, R: IntoIterator<Item = &'a Host>>( &'a self, txn_id: TxnId, to_remove: R ) -> TCResult<()>
Remove one or more replicas from this Cluster
.
Trait Implementations§
source§impl<T: Transact + Clone + Send + Sync + 'static> Dispatch for Cluster<Dir<T>>where
Cluster<BlockChain<T>>: Route<State>,
BlockChain<T>: Replica,
Dir<T>: Replica,
Self: Route<State>,
impl<T: Transact + Clone + Send + Sync + 'static> Dispatch for Cluster<Dir<T>>where
Cluster<BlockChain<T>>: Route<State>,
BlockChain<T>: Replica,
Dir<T>: Replica,
Self: Route<State>,
source§fn get<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 Txn,
path: &'life2 [PathSegment],
key: Value
) -> Pin<Box<dyn Future<Output = TCResult<State>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn get<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 Txn,
path: &'life2 [PathSegment],
key: Value
) -> Pin<Box<dyn Future<Output = TCResult<State>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Route a GET request.
source§fn put<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 Txn,
path: &'life2 [PathSegment],
key: Value,
value: State
) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn put<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 Txn,
path: &'life2 [PathSegment],
key: Value,
value: State
) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Route a PUT request.
source§fn post<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 Txn,
path: &'life2 [PathSegment],
data: State
) -> Pin<Box<dyn Future<Output = TCResult<State>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn post<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 Txn,
path: &'life2 [PathSegment],
data: State
) -> Pin<Box<dyn Future<Output = TCResult<State>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Route a POST request.
source§fn delete<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 Txn,
path: &'life2 [PathSegment],
key: Value
) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn delete<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 Txn,
path: &'life2 [PathSegment],
key: Value
) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Route a DELETE request.
source§impl<T> Persist<CacheBlock> for Cluster<BlockChain<T>>where
T: Persist<CacheBlock, Txn = Txn>,
BlockChain<T>: Persist<CacheBlock, Schema = (), Txn = Txn>,
impl<T> Persist<CacheBlock> for Cluster<BlockChain<T>>where
T: Persist<CacheBlock, Txn = Txn>,
BlockChain<T>: Persist<CacheBlock, Schema = (), Txn = Txn>,
type Txn = Txn<State>
type Schema = Schema
source§fn create<'async_trait>(
txn_id: TxnId,
schema: Self::Schema,
store: Dir
) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>where
Self: 'async_trait,
fn create<'async_trait>(
txn_id: TxnId,
schema: Self::Schema,
store: Dir
) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>where
Self: 'async_trait,
Create a new instance of
Self
from an empty Store
.source§fn load<'async_trait>(
txn_id: TxnId,
schema: Self::Schema,
store: Dir
) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>where
Self: 'async_trait,
fn load<'async_trait>(
txn_id: TxnId,
schema: Self::Schema,
store: Dir
) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>where
Self: 'async_trait,
Load a saved instance of
Self
from persistent storage.
Should only be invoked at startup time.source§fn dir(&self) -> Inner<CacheBlock>
fn dir(&self) -> Inner<CacheBlock>
Access the filesystem directory backing this persistent data structure.
source§impl<T> Persist<CacheBlock> for Cluster<Dir<T>>
impl<T> Persist<CacheBlock> for Cluster<Dir<T>>
type Txn = Txn<State>
type Schema = Schema
source§fn create<'async_trait>(
txn_id: TxnId,
schema: Self::Schema,
store: Dir
) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>where
Self: 'async_trait,
fn create<'async_trait>(
txn_id: TxnId,
schema: Self::Schema,
store: Dir
) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>where
Self: 'async_trait,
Create a new instance of
Self
from an empty Store
.source§fn load<'async_trait>(
txn_id: TxnId,
schema: Self::Schema,
store: Dir
) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>where
Self: 'async_trait,
fn load<'async_trait>(
txn_id: TxnId,
schema: Self::Schema,
store: Dir
) -> Pin<Box<dyn Future<Output = TCResult<Self>> + Send + 'async_trait>>where
Self: 'async_trait,
Load a saved instance of
Self
from persistent storage.
Should only be invoked at startup time.source§fn dir(&self) -> Inner<CacheBlock>
fn dir(&self) -> Inner<CacheBlock>
Access the filesystem directory backing this persistent data structure.
source§impl<T> Recover<CacheBlock> for Cluster<T>
impl<T> Recover<CacheBlock> for Cluster<T>
type Txn = Txn<State>
source§fn recover<'life0, 'life1, 'async_trait>(
&'life0 self,
txn: &'life1 Txn
) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn recover<'life0, 'life1, 'async_trait>(
&'life0 self,
txn: &'life1 Txn
) -> Pin<Box<dyn Future<Output = TCResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Recover this state after loading, in case the last transaction failed or was interrupted.
source§impl<T> Transact for Cluster<T>
impl<T> Transact for Cluster<T>
source§fn commit<'life0, 'async_trait>(
&'life0 self,
txn_id: TxnId
) -> Pin<Box<dyn Future<Output = Self::Commit> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn commit<'life0, 'async_trait>(
&'life0 self,
txn_id: TxnId
) -> Pin<Box<dyn Future<Output = Self::Commit> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Commit this transaction.
Auto Trait Implementations§
impl<T> !RefUnwindSafe for Cluster<T>
impl<T> Send for Cluster<T>where
T: Send,
impl<T> Sync for Cluster<T>where
T: Sync,
impl<T> Unpin for Cluster<T>where
T: Unpin,
impl<T> !UnwindSafe for Cluster<T>
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> 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>
source§impl<F> Match for F
impl<F> Match for F
source§fn matches<T>(&self) -> boolwhere
T: TryCastFrom<Self>,
fn matches<T>(&self) -> boolwhere
T: TryCastFrom<Self>,
Returns
true
if self
can be cast into the target type T
.§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<State, T> Public<State> for T
impl<State, T> Public<State> for T
fn get<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 <State as StateInstance>::Txn,
path: &'life2 [Id],
key: Value
) -> Pin<Box<dyn Future<Output = Result<State, TCError>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
T: 'async_trait,
fn put<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 <State as StateInstance>::Txn,
path: &'life2 [Id],
key: Value,
value: State
) -> Pin<Box<dyn Future<Output = Result<(), TCError>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
T: 'async_trait,
fn post<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 <State as StateInstance>::Txn,
path: &'life2 [Id],
params: Map<State>
) -> Pin<Box<dyn Future<Output = Result<State, TCError>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
T: 'async_trait,
fn delete<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
txn: &'life1 <State as StateInstance>::Txn,
path: &'life2 [Id],
key: Value
) -> Pin<Box<dyn Future<Output = Result<(), TCError>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
T: 'async_trait,
source§impl<F, T> TryCastFrom<F> for Twhere
T: CastFrom<F>,
impl<F, T> TryCastFrom<F> for Twhere
T: CastFrom<F>,
source§fn can_cast_from(_: &F) -> bool
fn can_cast_from(_: &F) -> bool
Test if
value
can be cast into Self
.source§fn opt_cast_from(f: F) -> Option<T>
fn opt_cast_from(f: F) -> Option<T>
Returns
Some(Self)
if the source value can be cast into Self
, otherwise None
.source§impl<F, T> TryCastInto<T> for Fwhere
T: TryCastFrom<F>,
impl<F, T> TryCastInto<T> for Fwhere
T: TryCastFrom<F>,
source§fn can_cast_into(&self) -> bool
fn can_cast_into(&self) -> bool
Test if
self
can be cast into T
.source§fn opt_cast_into(self) -> Option<T>
fn opt_cast_into(self) -> Option<T>
Returns
Some(T)
if self
can be cast into T
, otherwise None
.