Struct ethers_providers::RetryClient
source · pub struct RetryClient<T>where
T: JsonRpcClient,
T::Error: Sync + Send + 'static,{ /* private fields */ }
Expand description
RetryClient presents as a wrapper around JsonRpcClient that will retry requests based with an exponential backoff and filtering based on RetryPolicy.
The RetryPolicy
, mainly for rate-limiting errors, can be adjusted for specific applications,
endpoints. In addition to the RetryPolicy
errors due to connectivity issues, like timed out
connections or responses in range 5xx
can be retried separately.
Example
use ethers_providers::{Http, RetryClient, RetryClientBuilder, HttpRateLimitRetryPolicy};
use std::time::Duration;
use url::Url;
let http = Http::new(Url::parse("http://localhost:8545").unwrap());
let client = RetryClientBuilder::default()
.rate_limit_retries(10)
.timeout_retries(3)
.initial_backoff(Duration::from_millis(500))
.build(http, Box::new(HttpRateLimitRetryPolicy::default()));
Implementations§
source§impl<T> RetryClient<T>where
T: JsonRpcClient,
T::Error: Sync + Send + 'static,
impl<T> RetryClient<T>where
T: JsonRpcClient,
T::Error: Sync + Send + 'static,
sourcepub fn new(
inner: T,
policy: Box<dyn RetryPolicy<T::Error>>,
max_retry: u32,
initial_backoff: u64
) -> Self
pub fn new(
inner: T,
policy: Box<dyn RetryPolicy<T::Error>>,
max_retry: u32,
initial_backoff: u64
) -> Self
Creates a new RetryClient
that wraps a client and adds retry and backoff support
Example
use ethers_providers::{Http, RetryClient, HttpRateLimitRetryPolicy};
use std::time::Duration;
use url::Url;
let http = Http::new(Url::parse("http://localhost:8545").unwrap());
let backoff_timeout = 3000; // in ms
let max_retries = 10;
let client = RetryClient::new(http, Box::new(HttpRateLimitRetryPolicy::default()), max_retries, backoff_timeout);
sourcepub fn set_compute_units(&mut self, cpus: u64) -> &mut Self
pub fn set_compute_units(&mut self, cpus: u64) -> &mut Self
Sets the free compute units per second limit.
This is the maximum number of weighted request that can be handled per second by the endpoint before rate limit kicks in.
This is used to guesstimate how long to wait until to retry again
Trait Implementations§
source§impl<T: Debug> Debug for RetryClient<T>where
T: JsonRpcClient,
T::Error: Sync + Send + 'static,
T::Error: Debug,
impl<T: Debug> Debug for RetryClient<T>where
T: JsonRpcClient,
T::Error: Sync + Send + 'static,
T::Error: Debug,
source§impl<T> JsonRpcClient for RetryClient<T>where
T: JsonRpcClient + 'static,
T::Error: Sync + Send + 'static,
impl<T> JsonRpcClient for RetryClient<T>where
T: JsonRpcClient + 'static,
T::Error: Sync + Send + 'static,
§type Error = RetryClientError
type Error = RetryClientError
A JSON-RPC Error
source§fn request<'life0, 'life1, 'async_trait, A, R>(
&'life0 self,
method: &'life1 str,
params: A
) -> Pin<Box<dyn Future<Output = Result<R, Self::Error>> + Send + 'async_trait>>where
A: Debug + Serialize + Send + Sync,
R: DeserializeOwned,
A: 'async_trait,
R: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Self: 'async_trait,
fn request<'life0, 'life1, 'async_trait, A, R>(
&'life0 self,
method: &'life1 str,
params: A
) -> Pin<Box<dyn Future<Output = Result<R, Self::Error>> + Send + 'async_trait>>where
A: Debug + Serialize + Send + Sync,
R: DeserializeOwned,
A: 'async_trait,
R: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Self: 'async_trait,
Sends a request with the provided JSON-RPC and parameters serialized as JSON