Struct Sync

Source
pub struct Sync<N: Network> { /* private fields */ }
Expand description

Block synchronization logic for validators.

Synchronization works differently for nodes that act as validators in AleoBFT; In the common case, validators generate blocks after receiving an anchor block that has been accepted by a supermajority of the committee instead of fetching entire blocks from other nodes. However, if a validator does not have an up-to-date DAG, it might still fetch entire blocks from other nodes.

This struct also manages fetching certificates from other validators during normal operation, and blocks when falling behind.

Finally, Sync handles synchronization of blocks with the validator’s local storage: it loads blocks from the storage on startup and writes new blocks to the storage after discovering them.

Implementations§

Source§

impl<N: Network> Sync<N>

Source

pub fn new( gateway: Gateway<N>, storage: Storage<N>, ledger: Arc<dyn LedgerService<N>>, block_sync: Arc<BlockSync<N>>, ) -> Self

Initializes a new sync instance.

Source

pub async fn initialize(&self, bft_sender: Option<BFTSender<N>>) -> Result<()>

Initializes the sync module and sync the storage with the ledger at bootup.

Source

pub async fn run( &self, ping: Option<Arc<Ping<N>>>, sync_receiver: SyncReceiver<N>, ) -> Result<()>

Starts the sync module.

When this function returns successfully, the sync module will have spawned background tasks that fetch blocks from other validators.

Source§

impl<N: Network> Sync<N>

Source

pub fn is_synced(&self) -> bool

Returns true if the node is synced and has connected peers.

Source

pub fn num_blocks_behind(&self) -> Option<u32>

Returns the number of blocks the node is behind the greatest peer height.

Source

pub fn get_block_locators(&self) -> Result<BlockLocators<N>>

Returns the current block locators of the node.

Source§

impl<N: Network> Sync<N>

Source

pub async fn send_certificate_request( &self, peer_ip: SocketAddr, certificate_id: Field<N>, ) -> Result<BatchCertificate<N>>

Sends a certificate request to the specified peer.

Source§

impl<N: Network> Sync<N>

Source

pub async fn shut_down(&self)

Shuts down the primary.

Trait Implementations§

Source§

impl<N: Clone + Network> Clone for Sync<N>

Source§

fn clone(&self) -> Sync<N>

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

Auto Trait Implementations§

§

impl<N> Freeze for Sync<N>

§

impl<N> !RefUnwindSafe for Sync<N>

§

impl<N> Send for Sync<N>

§

impl<N> Sync for Sync<N>

§

impl<N> Unpin for Sync<N>

§

impl<N> !UnwindSafe for Sync<N>

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

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

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

Source§

type Output = T

Should always be Self
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> ErasedDestructor for T
where T: 'static,