0
0
mirror of https://github.com/thegeeklab/retry.git synced 2024-11-21 23:20:40 +00:00
retry/README.md

142 lines
3.9 KiB
Markdown
Raw Normal View History

2021-05-17 11:40:25 +00:00
# retry
2022-11-02 20:34:28 +00:00
Poor-mans servie synchronizer
[![Build Status](https://img.shields.io/drone/build/thegeeklab/retry?logo=drone&server=https%3A%2F%2Fdrone.thegeeklab.de)](https://drone.thegeeklab.de/thegeeklab/retry)
[![Docker Hub](https://img.shields.io/badge/dockerhub-latest-blue.svg?logo=docker&logoColor=white)](https://hub.docker.com/r/thegeeklab/retry)
[![Quay.io](https://img.shields.io/badge/quay-latest-blue.svg?logo=docker&logoColor=white)](https://quay.io/repository/thegeeklab/retry)
[![GitHub contributors](https://img.shields.io/github/contributors/thegeeklab/retry)](https://github.com/thegeeklab/retry/graphs/contributors)
[![Source: GitHub](https://img.shields.io/badge/source-github-blue.svg?logo=github&logoColor=white)](https://github.com/thegeeklab/retry)
[![License: MIT](https://img.shields.io/github/license/thegeeklab/retry)](https://github.com/thegeeklab/retry/blob/main/LICENSE)
2015-03-26 19:06:47 +00:00
Retry any shell command with exponential backoff or constant delay.
2021-05-17 11:40:25 +00:00
## Instructions
2015-03-26 19:06:47 +00:00
Install:
retry is a shell script, so drop it somewhere and make sure it's added to your \$PATH. Or you can use the following one-liner:
2021-05-17 11:40:25 +00:00
```Shell
2022-11-02 20:34:28 +00:00
curl -SsfL -o /usr/local/bin/retry https://raw.githubusercontent.com/thegeeklab/retry/main/retry && chmod +x /usr/local/bin/retry
```
2021-05-17 11:40:25 +00:00
## Usage
2015-03-26 19:06:47 +00:00
Help:
2021-05-17 11:40:25 +00:00
```Shell
retry -?
Usage: retry [options] -- execute command
-h, -?, --help
-v, --verbose Verbose output
-t, --tries=# Set max retries: Default 10
-s, --sleep=secs Constant sleep amount (seconds)
-m, --min=secs Exponential Backoff: minimum sleep amount (seconds): Default 0.3
-x, --max=secs Exponential Backoff: maximum sleep amount (seconds): Default 60
-f, --fail="script +cmds" Fail Script: run in case of final failure
```
2021-05-17 11:40:25 +00:00
## Examples
2015-03-26 19:06:47 +00:00
2015-03-26 19:24:45 +00:00
No problem:
2021-05-17 11:40:25 +00:00
```Shell
retry echo u work good
2015-03-26 19:24:45 +00:00
2021-05-17 11:40:25 +00:00
u work good
```
2015-03-26 19:24:45 +00:00
2015-03-26 19:06:47 +00:00
Test functionality:
2021-05-17 11:40:25 +00:00
```Shell
retry 'echo "y u no work"; false'
y u no work
Before retry #1: sleeping 0.3 seconds
y u no work
Before retry #2: sleeping 0.6 seconds
y u no work
Before retry #3: sleeping 1.2 seconds
y u no work
Before retry #4: sleeping 2.4 seconds
y u no work
Before retry #5: sleeping 4.8 seconds
y u no work
Before retry #6: sleeping 9.6 seconds
y u no work
Before retry #7: sleeping 19.2 seconds
y u no work
Before retry #8: sleeping 38.4 seconds
y u no work
Before retry #9: sleeping 60.0 seconds
y u no work
Before retry #10: sleeping 60.0 seconds
y u no work
etc..
```
2015-03-26 19:06:47 +00:00
Limit retries:
2021-05-17 11:40:25 +00:00
```Shell
retry -t 4 'echo "y u no work"; false'
y u no work
Before retry #1: sleeping 0.3 seconds
y u no work
Before retry #2: sleeping 0.6 seconds
y u no work
Before retry #3: sleeping 1.2 seconds
y u no work
Before retry #4: sleeping 2.4 seconds
y u no work
Retries exhausted
```
2015-03-26 19:06:47 +00:00
Bad command:
2021-05-17 11:40:25 +00:00
```Shell
retry poop
2015-03-26 19:06:47 +00:00
2021-05-17 11:40:25 +00:00
bash: poop: command not found
```
2015-03-26 19:06:47 +00:00
Fail command:
2021-05-17 11:40:25 +00:00
```Shell
retry -t 3 -f 'echo "oh poopsickles"' 'echo "y u no work"; false'
y u no work
Before retry #1: sleeping 0.3 seconds
y u no work
Before retry #2: sleeping 0.6 seconds
y u no work
Before retry #3: sleeping 1.2 seconds
y u no work
Retries exhausted, running fail script
oh poopsickles
```
Last attempt passed:
2021-05-17 11:40:25 +00:00
```Shell
retry -t 3 -- 'if [ $RETRY_ATTEMPT -eq 3 ]; then echo Passed at attempt $RETRY_ATTEMPT; true; else echo Failed at attempt $RETRY_ATTEMPT; false; fi;'
2021-05-17 11:40:25 +00:00
Failed at attempt 0
Before retry #1: sleeping 0.3 seconds
Failed at attempt 1
Before retry #2: sleeping 0.6 seconds
Failed at attempt 2
Before retry #3: sleeping 1.2 seconds
Passed at attempt 3
```
2022-11-02 20:34:28 +00:00
## Contributors
2015-03-26 19:06:47 +00:00
2022-11-02 20:34:28 +00:00
Special thanks to all [contributors](https://github.com/thegeeklab/retry/graphs/contributors). If you would like to contribute, please see the [instructions](https://github.com/thegeeklab/retry/blob/main/CONTRIBUTING.md).
2022-11-02 20:34:28 +00:00
## License
2022-11-02 20:34:28 +00:00
This project is licensed under the Apache 2.0 License - see the [LICENSE](https://github.com/thegeeklab/retry/blob/main/LICENSE) file for details.