pub mod bookmark;
pub mod cascade;
pub mod cdc;
pub mod commit_policy;
pub mod commit_waiter;
pub mod election;
pub mod failover;
pub mod fence;
pub mod flow_control;
pub mod lease;
pub mod logical;
pub mod primary;
pub mod quorum;
pub mod replica;
pub mod rollback;
pub mod scheduler;
pub mod swap_db;
pub mod topology_advertiser;
pub mod witness;
pub use bookmark::{BookmarkDecodeError, CausalBookmark};
pub use cascade::{
plan_upstream, CascadeRefusal, CascadeRelay, CascadeUpstream, DownstreamSlot, ReplicaClass,
UpstreamChoice,
};
pub use commit_policy::CommitPolicy;
pub use commit_waiter::{AwaitOutcome, CommitWaiter};
pub use election::{
quorum_threshold, randomized_election_timeout, ElectionCoordinator, ElectionOutcome,
ElectionRequest, ElectionTransport, FileLastVoteStore, LastVote, LastVoteError, LastVoteStore,
Member, MemberKind, MemoryLastVoteStore, RefusalReason, VoteDecision, VoteRequest, Voter,
VotingState,
};
pub use failover::{
FailoverCoordinator, FailoverError, FailoverMode, FailoverNode, FailoverOutcome,
FailoverRequest, FailoverTransport, NodeRole, RoleAssignment,
};
pub use fence::{
FenceBoundary, FenceVerdict, FileTermStore, MemoryTermStore, StaleTermFenced, TermFence,
TermStore, TermStoreError,
};
pub use flow_control::{Admission, FlowController};
pub use lease::{LeaseError, LeaseStore, WriterLease};
pub use quorum::{QuorumConfig, QuorumCoordinator, QuorumError};
pub use rollback::{
DivergentTail, RollbackCoordinator, RollbackError, RollbackEvent, RollbackOutcome,
RollbackPlan, RollbackRequest, RollbackTransport, TailRecord,
};
pub use swap_db::{RebootstrapInProgress, SwapDb};
pub use topology_advertiser::{
LagConfig, TopologyAdvertiser, TopologyAuthGate, DEFAULT_REPLICA_TIMEOUT_MS,
TOPOLOGY_READ_CAPABILITY,
};
pub use witness::{RuntimeProfile, WitnessSupervisor};
pub const DEFAULT_REPLICATION_TERM: u64 = 1;
pub const DEFAULT_SLOT_RETENTION_MAX_LAG_LSN: u64 = 100_000;
pub const DEFAULT_SLOT_IDLE_TIMEOUT_MS: u64 = 86_400_000;
#[derive(Debug, Clone, PartialEq, Eq, Default)]
pub enum ReplicationRole {
#[default]
Standalone,
Primary,
Replica {
primary_addr: String,
},
}
#[derive(Debug, Clone)]
pub struct ReplicationConfig {
pub role: ReplicationRole,
pub term: u64,
pub poll_interval_ms: u64,
pub max_batch_size: usize,
pub region: String,
pub quorum: QuorumConfig,
pub slot_retention_max_lag_lsn: u64,
pub slot_idle_timeout_ms: u64,
pub replica_class: ReplicaClass,
pub cascade_from: Option<CascadeUpstream>,
}
impl ReplicationConfig {
pub fn standalone() -> Self {
Self {
role: ReplicationRole::Standalone,
term: DEFAULT_REPLICATION_TERM,
poll_interval_ms: 100,
max_batch_size: 1000,
region: "local".to_string(),
quorum: QuorumConfig::async_commit(),
slot_retention_max_lag_lsn: DEFAULT_SLOT_RETENTION_MAX_LAG_LSN,
slot_idle_timeout_ms: DEFAULT_SLOT_IDLE_TIMEOUT_MS,
replica_class: ReplicaClass::Voting,
cascade_from: None,
}
}
pub fn primary() -> Self {
Self {
role: ReplicationRole::Primary,
term: DEFAULT_REPLICATION_TERM,
poll_interval_ms: 100,
max_batch_size: 1000,
region: "local".to_string(),
quorum: QuorumConfig::async_commit(),
slot_retention_max_lag_lsn: DEFAULT_SLOT_RETENTION_MAX_LAG_LSN,
slot_idle_timeout_ms: DEFAULT_SLOT_IDLE_TIMEOUT_MS,
replica_class: ReplicaClass::Voting,
cascade_from: None,
}
}
pub fn replica(primary_addr: impl Into<String>) -> Self {
Self {
role: ReplicationRole::Replica {
primary_addr: primary_addr.into(),
},
term: DEFAULT_REPLICATION_TERM,
poll_interval_ms: 100,
max_batch_size: 1000,
region: "local".to_string(),
quorum: QuorumConfig::async_commit(),
slot_retention_max_lag_lsn: DEFAULT_SLOT_RETENTION_MAX_LAG_LSN,
slot_idle_timeout_ms: DEFAULT_SLOT_IDLE_TIMEOUT_MS,
replica_class: ReplicaClass::Voting,
cascade_from: None,
}
}
pub fn with_quorum(mut self, quorum: QuorumConfig) -> Self {
self.quorum = quorum;
self
}
pub fn with_region(mut self, region: impl Into<String>) -> Self {
self.region = region.into();
self
}
pub fn with_term(mut self, term: u64) -> Self {
self.term = term;
self
}
pub fn with_slot_retention_max_lag_lsn(mut self, max_lag_lsn: u64) -> Self {
self.slot_retention_max_lag_lsn = max_lag_lsn;
self
}
pub fn with_slot_idle_timeout_ms(mut self, timeout_ms: u64) -> Self {
self.slot_idle_timeout_ms = timeout_ms;
self
}
pub fn with_replica_class(mut self, class: ReplicaClass) -> Self {
self.replica_class = class;
self
}
pub fn cascading_from(mut self, node_id: impl Into<String>, addr: impl Into<String>) -> Self {
self.replica_class = ReplicaClass::AsyncReadReplica;
self.cascade_from = Some(CascadeUpstream::new(node_id, addr));
self
}
pub fn resolved_upstream(
&self,
self_node_id: &str,
) -> (UpstreamChoice, Option<CascadeRefusal>) {
plan_upstream(self_node_id, self.replica_class, self.cascade_from.as_ref())
}
}