Skip to content

Commit

Permalink
Merge pull request #5327 from stacks-network/chore/event-dispatcher-logs
Browse files Browse the repository at this point in the history
Improvements to event dispatcher retry logic
  • Loading branch information
kantai authored Oct 18, 2024
2 parents f245115 + 2b36268 commit 3d1f829
Showing 1 changed file with 14 additions and 3 deletions.
17 changes: 14 additions & 3 deletions testnet/stacks-node/src/event_dispatcher.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ use clarity::vm::analysis::contract_interface_builder::build_contract_interface;
use clarity::vm::costs::ExecutionCost;
use clarity::vm::events::{FTEventType, NFTEventType, STXEventType};
use clarity::vm::types::{AssetIdentifier, QualifiedContractIdentifier, Value};
use rand::Rng;
use rusqlite::{params, Connection};
use serde_json::json;
use stacks::burnchains::{PoxConstants, Txid};
Expand Down Expand Up @@ -429,6 +430,10 @@ impl EventObserver {
.unwrap_or(PeerHost::DNS(host.to_string(), port));

let mut backoff = Duration::from_millis(100);
let mut attempts: i32 = 0;
// Cap the backoff at 3x the timeout
let max_backoff = timeout.saturating_mul(3);

loop {
let mut request = StacksHttpRequest::new_for_peer(
peerhost.clone(),
Expand All @@ -438,7 +443,6 @@ impl EventObserver {
)
.unwrap_or_else(|_| panic!("FATAL: failed to encode infallible data as HTTP request"));
request.add_header("Connection".into(), "close".into());

match send_http_request(host, port, request, timeout) {
Ok(response) => {
if response.preamble().status_code == 200 {
Expand All @@ -455,7 +459,9 @@ impl EventObserver {
Err(err) => {
warn!(
"Event dispatcher: connection or request failed to {}:{} - {:?}",
&host, &port, err
&host, &port, err;
"backoff" => ?backoff,
"attempts" => attempts
);
}
}
Expand All @@ -471,7 +477,12 @@ impl EventObserver {
}

sleep(backoff);
backoff *= 2;
let jitter: u64 = rand::thread_rng().gen_range(0..100);
backoff = std::cmp::min(
backoff.saturating_mul(2) + Duration::from_millis(jitter),
max_backoff,
);
attempts = attempts.saturating_add(1);
}
}

Expand Down

0 comments on commit 3d1f829

Please sign in to comment.