From d1c9fdabfca1a4c13eac7ca26842e1b8798e83e3 Mon Sep 17 00:00:00 2001 From: Riccardo Casatta Date: Mon, 30 Sep 2024 14:46:00 +0200 Subject: [PATCH] getblocks retry 5 times on 'Block not found on disk' --- src/daemon.rs | 31 +++++++++++++++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) diff --git a/src/daemon.rs b/src/daemon.rs index c3474e355..bc50e71ae 100644 --- a/src/daemon.rs +++ b/src/daemon.rs @@ -40,6 +40,9 @@ lazy_static! { ); } +const MAX_ATTEMPTS: u32 = 5; +const RETRY_WAIT_DURATION: Duration = Duration::from_secs(1); + #[instrument(skip_all, name="Daemon::parse_hash")] fn parse_hash(value: &Value) -> Result where @@ -552,7 +555,28 @@ impl Daemon { .iter() .map(|hash| json!([hash, /*verbose=*/ false])) .collect(); - let values = self.requests("getblock", params_list)?; + + let mut attempts = MAX_ATTEMPTS; + let values = loop { + attempts -= 1; + + match self.requests("getblock", params_list.clone()) { + Ok(blocks) => break blocks, + Err(e) => { + let err_msg = format!("{e:?}"); + if err_msg.contains("Block not found on disk") { + // There is a small chance the node returns the header but didn't finish to index the block + log::warn!("getblocks failing with: {e:?} trying {attempts} more time") + } else { + panic!("failed to get blocks from bitcoind: {}", err_msg); + } + } + } + if attempts == 0 { + panic!("failed to get blocks from bitcoind") + } + std::thread::sleep(RETRY_WAIT_DURATION); + }; let mut blocks = vec![]; for value in values { blocks.push(block_from_value(value)?); @@ -628,7 +652,10 @@ impl Daemon { #[allow(clippy::float_cmp)] #[instrument(skip_all, name="Daemon::estimatesmartfee_batch")] pub fn estimatesmartfee_batch(&self, conf_targets: &[u16]) -> Result> { - let params_list: Vec = conf_targets.iter().map(|t| json!([t, "ECONOMICAL"])).collect(); + let params_list: Vec = conf_targets + .iter() + .map(|t| json!([t, "ECONOMICAL"])) + .collect(); Ok(self .requests("estimatesmartfee", params_list)?