From dc76355150a7d5d305d09cf75c78f89d8a1adb30 Mon Sep 17 00:00:00 2001 From: Jonah Nestrick Date: Fri, 15 Mar 2024 11:48:25 -0400 Subject: [PATCH] Improve: Update example network err implementation Update the example to return unreachable error for connection errors to prevent immediate retries. --- .../src/network/raft_network_impl.rs | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/examples/raft-kv-memstore/src/network/raft_network_impl.rs b/examples/raft-kv-memstore/src/network/raft_network_impl.rs index db76ed109..59feb91e9 100644 --- a/examples/raft-kv-memstore/src/network/raft_network_impl.rs +++ b/examples/raft-kv-memstore/src/network/raft_network_impl.rs @@ -1,6 +1,7 @@ use openraft::error::InstallSnapshotError; use openraft::error::NetworkError; use openraft::error::RemoteError; +use openraft::error::Unreachable; use openraft::network::RPCOption; use openraft::network::RaftNetwork; use openraft::network::RaftNetworkFactory; @@ -41,12 +42,14 @@ impl Network { let client = reqwest::Client::new(); tracing::debug!("client is created for: {}", url); - let resp = client - .post(url) - .json(&req) - .send() - .await - .map_err(|e| openraft::error::RPCError::Network(NetworkError::new(&e)))?; + let resp = client.post(url).json(&req).send().await.map_err(|e| { + // If the error is a connection error, we return Unreachable so that connection isn't retried + // immediately. + if e.is_connect() { + return openraft::error::RPCError::Unreachable(Unreachable::new(&e)); + } + openraft::error::RPCError::Network(NetworkError::new(&e)) + })?; tracing::debug!("client.post() is sent");