python requests请求失败重试_python http requests失败重试方法, 退避算法(Retrying HTTP Requests with Backoff)...

import requests

from datetime import datetime

import time

import random

retry_timeout = 10

def http_request(url, first_request_time=None, retry_counter=0):

"""

first_request_time: The time of the first request (None if no retries have occurred).

retry_counter: The number of this retry, or zero for first attempt.

"""

if not first_request_time:

first_request_time = datetime.now()

try:

elapsed = datetime.now() - first_request_time

if elapsed.total_seconds() > retry_timeout:

raise TimeoutError

if retry_counter > 0:

# 0.5 * (1.5 ^ i) is an increased sleep time of 1.5x per iteration,

# starting at 0.5s when retry_counter=0. The first retry will occur

# at 1, so subtract that first.

delay_seconds = 0.5 * 1.5**(retry_counter - 1)

print(f"Delay {delay_seconds}")

# Jitter this value by 50% and pause.

time.sleep(delay_seconds * (random.random() + 0.5))

result = requests.get(url)

return result.text

except TimeoutError:

print("Request Timed out")

return None

except requests.exceptions.ConnectionError:

return http_request(url, first_request_time, retry_counter + 1)

if __name__ == "__main__":

response_text = http_request("https://thissitedoesntexist.com")

# retries the request to an invalid url until the timeout of 10 second is reached

# A TimeoutError is raised after 10 seconds

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于 Python 中使用 requests 库进行网络请求时,可以通过实现机制来处理请求失败的情况。以下是一个简单的实现示例: ```python import requests from requests.adapters import HTTPAdapter from requests.packages.urllib3.util.retry import Retry def requests_retry_session( retries=3, backoff_factor=0.3, status_forcelist=(500, 502, 504), session=None, ): session = session or requests.Session() retry = Retry( total=retries, read=retries, connect=retries, backoff_factor=backoff_factor, status_forcelist=status_forcelist, ) adapter = HTTPAdapter(max_retries=retry) session.mount('http://', adapter) session.mount('https://', adapter) return session # 使用示例 response = requests_retry_session().get('https://www.example.com') print(response.status_code) ``` 上述代码中,我们定义了一个名为 `requests_retry_session` 的函数来创建一个带有机制的 requests.Session 对象。在该函数中,我们使用了 `Retry` 类来配置策略,其中 `retries` 参数指定了最大次数,`backoff_factor` 参数指定了之间的延迟时间的乘数因子,`status_forcelist` 参数指定了需要触发的状态码列表。 然后,我们创建了一个 `HTTPAdapter` 对象,并将其与 `requests.Session` 对象进行关联,最后通过 `session.get()` 方法来发送请求并获取响应。 这样,在网络请求失败时,会自动进行,直到达到最大次数或成功获取到响应为止。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值