Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/coveooss/exponential-backoff
A utility that allows retrying a function with an exponential delay between attempts.
https://github.com/coveooss/exponential-backoff
Last synced: about 19 hours ago
JSON representation
A utility that allows retrying a function with an exponential delay between attempts.
- Host: GitHub
- URL: https://github.com/coveooss/exponential-backoff
- Owner: coveooss
- License: apache-2.0
- Created: 2018-07-05T19:22:09.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-08-20T22:18:46.000Z (5 months ago)
- Last Synced: 2025-01-05T09:06:25.064Z (8 days ago)
- Language: TypeScript
- Size: 326 KB
- Stars: 361
- Watchers: 10
- Forks: 26
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-javascript - exponential-backoff
- awesome-javascript - exponential-backoff
README
# exponential-backoff
A utility that allows retrying a function with an exponential delay between attempts.
## Installation
```
npm i exponential-backoff
```## Usage
The `backOff` function takes a promise-returning function to retry, and an optional `BackOffOptions` object. It returns a `Promise`.
```ts
function backOff(
request: () => Promise,
options?: BackOffOptions
): Promise;
```Here is an example retrying a function that calls a hypothetical weather endpoint:
```js
import { backOff } from "exponential-backoff";function getWeather() {
return fetch("weather-endpoint");
}async function main() {
try {
const response = await backOff(() => getWeather());
// process response
} catch (e) {
// handle error
}
}main();
```Migrating across major versions? Here are our [breaking changes](https://github.com/coveo/exponential-backoff/tree/master/doc/migration-guide.md).
### `BackOffOptions`
- `delayFirstAttempt?: boolean`
Decides whether the `startingDelay` should be applied before the first call. If `false`, the first call will occur without a delay.
Default value is `false`.
- `jitter?: JitterType | string`
Decides whether a [jitter](https://aws.amazon.com/blogs/architecture/exponential-backoff-and-jitter/) should be applied to the delay. Possible values are `full` and `none`.
Default value is `none`.
- `maxDelay?: number`
The maximum delay, in milliseconds, between two consecutive attempts.
Default value is `Infinity`.
- `numOfAttempts?: number`
The maximum number of times to attempt the function.
Default value is `10`.
Minimum value is `1`.
- `retry?: (e: any, attemptNumber: number) => boolean | Promise`
The `retry` function can be used to run logic after every failed attempt (e.g. logging a message, assessing the last error, etc.). It is called with the last error and the upcoming attempt number. Returning `true` will retry the function as long as the `numOfAttempts` has not been exceeded. Returning `false` will end the execution.
Default value is a function that always returns `true`.
- `startingDelay?: number`
The delay, in milliseconds, before executing the function for the first time.
Default value is `100` ms.
- `timeMultiple?: number`
The `startingDelay` is multiplied by the `timeMultiple` to increase the delay between reattempts.
Default value is `2`.