Skip to content

Commit

Permalink
[narwhal adpater] Add backoff mechanism to consensus adapter (#3548)
Browse files Browse the repository at this point in the history
* Add back-off mechanism to consensus adopter (both certs and fragments)
* Added more clear constants and function

Co-authored-by: George Danezis <george@danez.is>
  • Loading branch information
gdanezis and George Danezis authored Aug 5, 2022
1 parent be004a1 commit 486ed2c
Show file tree
Hide file tree
Showing 3 changed files with 219 additions and 14 deletions.
10 changes: 8 additions & 2 deletions crates/sui-core/src/authority_server.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@
use crate::{
authority::AuthorityState,
consensus_adapter::{
CheckpointConsensusAdapter, CheckpointSender, ConsensusAdapter, ConsensusListener,
ConsensusListenerMessage,
CheckpointConsensusAdapter, CheckpointSender, ConsensusAdapter, ConsensusAdapterMetrics,
ConsensusListener, ConsensusListenerMessage,
},
};
use anyhow::anyhow;
Expand Down Expand Up @@ -86,11 +86,13 @@ impl AuthorityServer {
consensus_address: Multiaddr,
tx_consensus_listener: Sender<ConsensusListenerMessage>,
) -> Self {
let metrics = ConsensusAdapterMetrics::new_test();
let consensus_adapter = ConsensusAdapter::new(
consensus_address,
state.clone_committee(),
tx_consensus_listener,
/* max_delay */ Duration::from_millis(20_000),
metrics,
);

Self {
Expand Down Expand Up @@ -206,12 +208,15 @@ impl ValidatorService {
/* max_pending_transactions */ 1_000_000,
);

let metrics = ConsensusAdapterMetrics::new(prometheus_registry);

// The consensus adapter allows the authority to send user certificates through consensus.
let consensus_adapter = ConsensusAdapter::new(
consensus_config.address().to_owned(),
state.clone_committee(),
tx_sui_to_consensus.clone(),
/* max_delay */ Duration::from_millis(5_000),
metrics.clone(),
);

// Update the checkpoint store with a consensus client.
Expand All @@ -229,6 +234,7 @@ impl ValidatorService {
/* checkpoint_locals */ checkpoint_store,
/* retry_delay */ Duration::from_millis(5_000),
/* max_pending_transactions */ 10_000,
metrics,
)
.spawn();
Some(handle)
Expand Down
Loading

0 comments on commit 486ed2c

Please sign in to comment.