Make requests's sessions auto-retry on failure.
Project description
Configures the passed-in requests’ Session to retry on failed requests due to connection errors, timeouts, specific HTTP response codes (5XX by default) and 30X redirections —anything that could fail.
Python 3.6+.
Basic usage:
from retry_requests import retry
my_session = retry()
my_session.get("http://foo.bar")
This get will retry three times in case of error waiting some time between retries. Errors could be:
Waiting for the server to start answering for 5 seconds.
No access to the server or a dropped connection.
An HTTP answer of 500, 502, or 504.
You can change these defaults:
from retry_requests import retry
from requests import Session
my_session = retry(Session(), retries=5, backoff_factor=0.2)
my_session.get('https://foo.bar')
Check the function retry to know more about this configuration.
Note that you have a TSession, a Session with a default timeout, and RSession, a Session with a timeout that always raise_for_status(), for your convenience.
Heavily inspired from Peterbe.com. Thank you!
Installing
Just pip install retry-requests.
Testing
Clone this project and then, at its root directory, run python setup.py test. Note that you need an active Internet connection to run the tests.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for retry_requests-2.0.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 38e8e3f55051e7b7915c1768884269097865a5da2ea87d5dcafd6ba9498c363f |
|
MD5 | 89c529072975d4251f18836aa09ddc0d |
|
BLAKE2b-256 | b1f38ce908497bebbc2790ef06240a2c0fb28c096abb59062d88f85090464a5f |