API documentation¶
API documentation serves as an important reference in technical documentation. Sphinx provides many approaches to writing API documentation, from writing them manually as well as automatically generating it from docstrings in your code.
This example uses sphinx.ext.autodoc
for generating the API documentation skeleton. sphinx.ext.intersphinx
provides links for classes in type annotations.
.. autoclass:: urllib3.util.Retry
:members:
:noindex:
.. autoclass:: urllib3.util.Timeout
:members:
:noindex:
This is a small example from reStructuredText.
- class urllib3.util.Retry(total=10, connect=None, read=None, redirect=None, status=None, other=None, allowed_methods=DEFAULT_ALLOWED_METHODS, status_forcelist=None, backoff_factor=0, backoff_max=DEFAULT_BACKOFF_MAX, raise_on_redirect=True, raise_on_status=True, history=None, respect_retry_after_header=True, remove_headers_on_redirect=DEFAULT_REMOVE_HEADERS_ON_REDIRECT, backoff_jitter=0.0)[source]
Retry configuration.
Each retry attempt will create a new Retry object with updated values, so they can be safely reused.
Retries can be defined as a default for a pool:
retries = Retry(connect=5, read=2, redirect=5) http = PoolManager(retries=retries) response = http.request("GET", "https://example.com/")
Or per-request (which overrides the default for the pool):
response = http.request("GET", "https://example.com/", retries=Retry(10))
Retries can be disabled by passing
False
:response = http.request("GET", "https://example.com/", retries=False)
Errors will be wrapped in
MaxRetryError
unless retries are disabled, in which case the causing exception will be raised.- Parameters:
total (int) –
Total number of retries to allow. Takes precedence over other counts.
Set to
None
to remove this constraint and fall back on other counts.Set to
0
to fail on the first retry.Set to
False
to disable and implyraise_on_redirect=False
.connect (int) –
How many connection-related errors to retry on.
These are errors raised before the request is sent to the remote server, which we assume has not triggered the server to process the request.
Set to
0
to fail on the first retry of this type.read (int) –
How many times to retry on read errors.
These errors are raised after the request was sent to the server, so the request may have side-effects.
Set to
0
to fail on the first retry of this type.redirect (int) –
How many redirects to perform. Limit this to avoid infinite redirect loops.
A redirect is a HTTP response with a status code 301, 302, 303, 307 or 308.
Set to
0
to fail on the first retry of this type.Set to
False
to disable and implyraise_on_redirect=False
.status (int) –
How many times to retry on bad status codes.
These are retries made on responses, where status code matches
status_forcelist
.Set to
0
to fail on the first retry of this type.other (int) –
How many times to retry on other errors.
Other errors are errors that are not connect, read, redirect or status errors. These errors might be raised after the request was sent to the server, so the request might have side-effects.
Set to
0
to fail on the first retry of this type.If
total
is not set, it’s a good idea to set this to 0 to account for unexpected edge cases and avoid infinite retry loops.allowed_methods (Collection) –
Set of uppercased HTTP method verbs that we should retry on.
By default, we only retry on methods which are considered to be idempotent (multiple requests with the same parameters end with the same state). See
Retry.DEFAULT_ALLOWED_METHODS
.Set to a
None
value to retry on any verb.status_forcelist (Collection) –
A set of integer HTTP status codes that we should force a retry on. A retry is initiated if the request method is in
allowed_methods
and the response status code is instatus_forcelist
.By default, this is disabled with
None
.backoff_factor (float) –
A backoff factor to apply between attempts after the second try (most errors are resolved immediately by a second try without a delay). urllib3 will sleep for:
{backoff factor} * (2 ** ({number of previous retries}))
seconds. If backoff_jitter is non-zero, this sleep is extended by:
random.uniform(0, {backoff jitter})
seconds. For example, if the backoff_factor is 0.1, then
Retry.sleep()
will sleep for [0.0s, 0.2s, 0.4s, 0.8s, …] between retries. No backoff will ever be longer than backoff_max.By default, backoff is disabled (factor set to 0).
raise_on_redirect (bool) – Whether, if the number of redirects is exhausted, to raise a MaxRetryError, or to return a response with a response code in the 3xx range.
raise_on_status (bool) – Similar meaning to
raise_on_redirect
: whether we should raise an exception, or return a response, if status falls instatus_forcelist
range and retries have been exhausted.history (tuple) – The history of the request encountered during each call to
increment()
. The list is in the order the requests occurred. Each list item is of classRequestHistory
.respect_retry_after_header (bool) – Whether to respect Retry-After header on status codes defined as
Retry.RETRY_AFTER_STATUS_CODES
or not.remove_headers_on_redirect (Collection) – Sequence of headers to remove from the request when a response indicating a redirect is returned before firing off the redirected request.
backoff_max (float)
backoff_jitter (float)
- DEFAULT_ALLOWED_METHODS = frozenset({'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PUT', 'TRACE'})
Default methods to be used for
allowed_methods
- RETRY_AFTER_STATUS_CODES = frozenset({413, 429, 503})
Default status codes to be used for
status_forcelist
- DEFAULT_REMOVE_HEADERS_ON_REDIRECT = frozenset({'Authorization', 'Cookie', 'Proxy-Authorization'})
Default headers to be used for
remove_headers_on_redirect
- DEFAULT_BACKOFF_MAX = 120
Default maximum backoff time.
- classmethod from_int(retries, redirect=True, default=None)[source]
Backwards-compatibility for the old retries format.
- get_retry_after(response)[source]
Get the value of Retry-After in seconds.
- Parameters:
response (BaseHTTPResponse)
- Return type:
float | None
- sleep(response=None)[source]
Sleep between retry attempts.
This method will respect a server’s
Retry-After
response header and sleep the duration of the time requested. If that is not present, it will use an exponential backoff. By default, the backoff factor is 0 and this method will return immediately.- Parameters:
response (BaseHTTPResponse | None)
- Return type:
None
- is_retry(method, status_code, has_retry_after=False)[source]
Is this method/status code retryable? (Based on allowlists and control variables such as the number of total retries to allow, whether to respect the Retry-After header, whether this header is present, and whether the returned status code is on the list of status codes to be retried upon on the presence of the aforementioned header)
- increment(method=None, url=None, response=None, error=None, _pool=None, _stacktrace=None)[source]
Return a new Retry object with incremented retry counters.
- Parameters:
response (
BaseHTTPResponse
) – A response object, or None, if the server did not return a response.error (Exception) – An error encountered during the request, or None if the response was received successfully.
method (str | None)
url (str | None)
_pool (ConnectionPool | None)
_stacktrace (TracebackType | None)
- Returns:
A new
Retry
object.- Return type:
Self
- class urllib3.util.Timeout(total=None, connect=_DEFAULT_TIMEOUT, read=_DEFAULT_TIMEOUT)[source]
Timeout configuration.
Timeouts can be defined as a default for a pool:
import urllib3 timeout = urllib3.util.Timeout(connect=2.0, read=7.0) http = urllib3.PoolManager(timeout=timeout) resp = http.request("GET", "https://example.com/") print(resp.status)
Or per-request (which overrides the default for the pool):
response = http.request("GET", "https://example.com/", timeout=Timeout(10))
Timeouts can be disabled by setting all the parameters to
None
:no_timeout = Timeout(connect=None, read=None) response = http.request("GET", "https://example.com/", timeout=no_timeout)
- Parameters:
This combines the connect and read timeouts into one; the read timeout will be set to the time leftover from the connect attempt. In the event that both a connect timeout and a total are specified, or a read timeout and a total are specified, the shorter timeout will be applied.
Defaults to None.
connect (int, float, or None) – The maximum amount of time (in seconds) to wait for a connection attempt to a server to succeed. Omitting the parameter will default the connect timeout to the system default, probably the global default timeout in socket.py. None will set an infinite timeout for connection attempts.
The maximum amount of time (in seconds) to wait between consecutive read operations for a response from the server. Omitting the parameter will default the read timeout to the system default, probably the global default timeout in socket.py. None will set an infinite timeout.
Note
Many factors can affect the total amount of time for urllib3 to return an HTTP response.
For example, Python’s DNS resolver does not obey the timeout specified on the socket. Other factors that can affect total request time include high CPU load, high swap, the program running at a low priority level, or other behaviors.
In addition, the read and total timeouts only measure the time between read operations on the socket connecting the client and the server, not the total amount of time for the request to return a complete response. For most requests, the timeout is raised because the server has not sent the first byte in the specified time. This is not always the case; if a server streams one byte every fifteen seconds, a timeout of 20 seconds will not trigger, even though the request will take several minutes to complete.
- DEFAULT_TIMEOUT: float | _TYPE_DEFAULT | None = -1
A sentinel object representing the default timeout value
- classmethod from_float(timeout)[source]
Create a new Timeout from a legacy timeout value.
The timeout value used by httplib.py sets the same timeout on the connect(), and recv() socket requests. This creates a
Timeout
object that sets the individual timeouts to thetimeout
value passed to this function.- Parameters:
timeout (integer, float,
urllib3.util.Timeout.DEFAULT_TIMEOUT
, or None) – The legacy timeout value.- Returns:
Timeout object
- Return type:
Timeout
- clone()[source]
Create a copy of the timeout object
Timeout properties are stored per-pool but each request needs a fresh Timeout object to ensure each one has its own start/stop configured.
- Returns:
a copy of the timeout object
- Return type:
Timeout
- start_connect()[source]
Start the timeout clock, used during a connect() attempt
- Raises:
urllib3.exceptions.TimeoutStateError – if you attempt to start a timer that has been started already.
- Return type:
- get_connect_duration()[source]
Gets the time elapsed since the call to
start_connect()
.- Returns:
Elapsed time in seconds.
- Return type:
- Raises:
urllib3.exceptions.TimeoutStateError – if you attempt to get duration for a timer that hasn’t been started.
- property connect_timeout: float | _TYPE_DEFAULT | None
Get the value to use when setting a connection timeout.
This will be a positive float or integer, the value None (never timeout), or the default system timeout.
- Returns:
Connect timeout.
- Return type:
int, float,
Timeout.DEFAULT_TIMEOUT
or None
- property read_timeout: float | None
Get the value for the read timeout.
This assumes some time has elapsed in the connection timeout and computes the read timeout appropriately.
If self.total is set, the read timeout is dependent on the amount of time taken by the connect timeout. If the connection time has not been established, a
TimeoutStateError
will be raised.
This is a small example from reStructuredText.
```{eval-rst}
.. autoclass:: urllib3.util.Retry
:members:
:noindex:
.. autoclass:: urllib3.util.Timeout
:members:
:noindex:
```
This is a small example from Markdown.
- class urllib3.util.Retry(total=10, connect=None, read=None, redirect=None, status=None, other=None, allowed_methods=DEFAULT_ALLOWED_METHODS, status_forcelist=None, backoff_factor=0, backoff_max=DEFAULT_BACKOFF_MAX, raise_on_redirect=True, raise_on_status=True, history=None, respect_retry_after_header=True, remove_headers_on_redirect=DEFAULT_REMOVE_HEADERS_ON_REDIRECT, backoff_jitter=0.0)[source]
Retry configuration.
Each retry attempt will create a new Retry object with updated values, so they can be safely reused.
Retries can be defined as a default for a pool:
retries = Retry(connect=5, read=2, redirect=5) http = PoolManager(retries=retries) response = http.request("GET", "https://example.com/")
Or per-request (which overrides the default for the pool):
response = http.request("GET", "https://example.com/", retries=Retry(10))
Retries can be disabled by passing
False
:response = http.request("GET", "https://example.com/", retries=False)
Errors will be wrapped in
MaxRetryError
unless retries are disabled, in which case the causing exception will be raised.- Parameters:
total (int) –
Total number of retries to allow. Takes precedence over other counts.
Set to
None
to remove this constraint and fall back on other counts.Set to
0
to fail on the first retry.Set to
False
to disable and implyraise_on_redirect=False
.connect (int) –
How many connection-related errors to retry on.
These are errors raised before the request is sent to the remote server, which we assume has not triggered the server to process the request.
Set to
0
to fail on the first retry of this type.read (int) –
How many times to retry on read errors.
These errors are raised after the request was sent to the server, so the request may have side-effects.
Set to
0
to fail on the first retry of this type.redirect (int) –
How many redirects to perform. Limit this to avoid infinite redirect loops.
A redirect is a HTTP response with a status code 301, 302, 303, 307 or 308.
Set to
0
to fail on the first retry of this type.Set to
False
to disable and implyraise_on_redirect=False
.status (int) –
How many times to retry on bad status codes.
These are retries made on responses, where status code matches
status_forcelist
.Set to
0
to fail on the first retry of this type.other (int) –
How many times to retry on other errors.
Other errors are errors that are not connect, read, redirect or status errors. These errors might be raised after the request was sent to the server, so the request might have side-effects.
Set to
0
to fail on the first retry of this type.If
total
is not set, it’s a good idea to set this to 0 to account for unexpected edge cases and avoid infinite retry loops.allowed_methods (Collection) –
Set of uppercased HTTP method verbs that we should retry on.
By default, we only retry on methods which are considered to be idempotent (multiple requests with the same parameters end with the same state). See
Retry.DEFAULT_ALLOWED_METHODS
.Set to a
None
value to retry on any verb.status_forcelist (Collection) –
A set of integer HTTP status codes that we should force a retry on. A retry is initiated if the request method is in
allowed_methods
and the response status code is instatus_forcelist
.By default, this is disabled with
None
.backoff_factor (float) –
A backoff factor to apply between attempts after the second try (most errors are resolved immediately by a second try without a delay). urllib3 will sleep for:
{backoff factor} * (2 ** ({number of previous retries}))
seconds. If backoff_jitter is non-zero, this sleep is extended by:
random.uniform(0, {backoff jitter})
seconds. For example, if the backoff_factor is 0.1, then
Retry.sleep()
will sleep for [0.0s, 0.2s, 0.4s, 0.8s, …] between retries. No backoff will ever be longer than backoff_max.By default, backoff is disabled (factor set to 0).
raise_on_redirect (bool) – Whether, if the number of redirects is exhausted, to raise a MaxRetryError, or to return a response with a response code in the 3xx range.
raise_on_status (bool) – Similar meaning to
raise_on_redirect
: whether we should raise an exception, or return a response, if status falls instatus_forcelist
range and retries have been exhausted.history (tuple) – The history of the request encountered during each call to
increment()
. The list is in the order the requests occurred. Each list item is of classRequestHistory
.respect_retry_after_header (bool) – Whether to respect Retry-After header on status codes defined as
Retry.RETRY_AFTER_STATUS_CODES
or not.remove_headers_on_redirect (Collection) – Sequence of headers to remove from the request when a response indicating a redirect is returned before firing off the redirected request.
backoff_max (float)
backoff_jitter (float)
- DEFAULT_ALLOWED_METHODS = frozenset({'DELETE', 'GET', 'HEAD', 'OPTIONS', 'PUT', 'TRACE'})
Default methods to be used for
allowed_methods
- RETRY_AFTER_STATUS_CODES = frozenset({413, 429, 503})
Default status codes to be used for
status_forcelist
- DEFAULT_REMOVE_HEADERS_ON_REDIRECT = frozenset({'Authorization', 'Cookie', 'Proxy-Authorization'})
Default headers to be used for
remove_headers_on_redirect
- DEFAULT_BACKOFF_MAX = 120
Default maximum backoff time.
- classmethod from_int(retries, redirect=True, default=None)[source]
Backwards-compatibility for the old retries format.
- get_retry_after(response)[source]
Get the value of Retry-After in seconds.
- Parameters:
response (BaseHTTPResponse)
- Return type:
float | None
- sleep(response=None)[source]
Sleep between retry attempts.
This method will respect a server’s
Retry-After
response header and sleep the duration of the time requested. If that is not present, it will use an exponential backoff. By default, the backoff factor is 0 and this method will return immediately.- Parameters:
response (BaseHTTPResponse | None)
- Return type:
None
- is_retry(method, status_code, has_retry_after=False)[source]
Is this method/status code retryable? (Based on allowlists and control variables such as the number of total retries to allow, whether to respect the Retry-After header, whether this header is present, and whether the returned status code is on the list of status codes to be retried upon on the presence of the aforementioned header)
- increment(method=None, url=None, response=None, error=None, _pool=None, _stacktrace=None)[source]
Return a new Retry object with incremented retry counters.
- Parameters:
response (
BaseHTTPResponse
) – A response object, or None, if the server did not return a response.error (Exception) – An error encountered during the request, or None if the response was received successfully.
method (str | None)
url (str | None)
_pool (ConnectionPool | None)
_stacktrace (TracebackType | None)
- Returns:
A new
Retry
object.- Return type:
Self
- class urllib3.util.Timeout(total=None, connect=_DEFAULT_TIMEOUT, read=_DEFAULT_TIMEOUT)[source]
Timeout configuration.
Timeouts can be defined as a default for a pool:
import urllib3 timeout = urllib3.util.Timeout(connect=2.0, read=7.0) http = urllib3.PoolManager(timeout=timeout) resp = http.request("GET", "https://example.com/") print(resp.status)
Or per-request (which overrides the default for the pool):
response = http.request("GET", "https://example.com/", timeout=Timeout(10))
Timeouts can be disabled by setting all the parameters to
None
:no_timeout = Timeout(connect=None, read=None) response = http.request("GET", "https://example.com/", timeout=no_timeout)
- Parameters:
This combines the connect and read timeouts into one; the read timeout will be set to the time leftover from the connect attempt. In the event that both a connect timeout and a total are specified, or a read timeout and a total are specified, the shorter timeout will be applied.
Defaults to None.
connect (int, float, or None) – The maximum amount of time (in seconds) to wait for a connection attempt to a server to succeed. Omitting the parameter will default the connect timeout to the system default, probably the global default timeout in socket.py. None will set an infinite timeout for connection attempts.
The maximum amount of time (in seconds) to wait between consecutive read operations for a response from the server. Omitting the parameter will default the read timeout to the system default, probably the global default timeout in socket.py. None will set an infinite timeout.
Note
Many factors can affect the total amount of time for urllib3 to return an HTTP response.
For example, Python’s DNS resolver does not obey the timeout specified on the socket. Other factors that can affect total request time include high CPU load, high swap, the program running at a low priority level, or other behaviors.
In addition, the read and total timeouts only measure the time between read operations on the socket connecting the client and the server, not the total amount of time for the request to return a complete response. For most requests, the timeout is raised because the server has not sent the first byte in the specified time. This is not always the case; if a server streams one byte every fifteen seconds, a timeout of 20 seconds will not trigger, even though the request will take several minutes to complete.
- DEFAULT_TIMEOUT: float | _TYPE_DEFAULT | None = -1
A sentinel object representing the default timeout value
- classmethod from_float(timeout)[source]
Create a new Timeout from a legacy timeout value.
The timeout value used by httplib.py sets the same timeout on the connect(), and recv() socket requests. This creates a
Timeout
object that sets the individual timeouts to thetimeout
value passed to this function.- Parameters:
timeout (integer, float,
urllib3.util.Timeout.DEFAULT_TIMEOUT
, or None) – The legacy timeout value.- Returns:
Timeout object
- Return type:
Timeout
- clone()[source]
Create a copy of the timeout object
Timeout properties are stored per-pool but each request needs a fresh Timeout object to ensure each one has its own start/stop configured.
- Returns:
a copy of the timeout object
- Return type:
Timeout
- start_connect()[source]
Start the timeout clock, used during a connect() attempt
- Raises:
urllib3.exceptions.TimeoutStateError – if you attempt to start a timer that has been started already.
- Return type:
- get_connect_duration()[source]
Gets the time elapsed since the call to
start_connect()
.- Returns:
Elapsed time in seconds.
- Return type:
- Raises:
urllib3.exceptions.TimeoutStateError – if you attempt to get duration for a timer that hasn’t been started.
- property connect_timeout: float | _TYPE_DEFAULT | None
Get the value to use when setting a connection timeout.
This will be a positive float or integer, the value None (never timeout), or the default system timeout.
- Returns:
Connect timeout.
- Return type:
int, float,
Timeout.DEFAULT_TIMEOUT
or None
- property read_timeout: float | None
Get the value for the read timeout.
This assumes some time has elapsed in the connection timeout and computes the read timeout appropriately.
If self.total is set, the read timeout is dependent on the amount of time taken by the connect timeout. If the connection time has not been established, a
TimeoutStateError
will be raised.
This is a small example from Markdown.