Python中網(wǎng)絡(luò)請求中Retry策略實(shí)現(xiàn)方式
網(wǎng)絡(luò)環(huán)境的不穩(wěn)定性及服務(wù)短暫不可達(dá)等因素可能導(dǎo)致HTTP請求失敗。為了強(qiáng)化Python客戶端的韌性和自我恢復(fù)能力,實(shí)現(xiàn)請求自動重試成為了一種常見的最佳實(shí)踐。
在Python生態(tài)系統(tǒng)中,requests
庫作為處理HTTP請求的標(biāo)準(zhǔn)工具備受青睞,但它自身并未直接提供重試機(jī)制,此時,我們需要借助urllib3
庫中的Retry
類來補(bǔ)充這一功能。
1. 重試機(jī)制的必要性
在大規(guī)模分布式系統(tǒng)環(huán)境下,服務(wù)間通信由于多種原因(如網(wǎng)絡(luò)抖動、服務(wù)瞬時不可達(dá)等)可能面臨失敗的風(fēng)險(xiǎn)。
通過引入自動重試機(jī)制,能夠有效提升系統(tǒng)的整體可靠性和容錯性能,尤其對于緩解暫時性故障造成的請求失敗現(xiàn)象,合理設(shè)計(jì)的重試策略顯得至關(guān)重要。
2. 實(shí)現(xiàn)重試機(jī)制的基本流程
在requests
庫中實(shí)現(xiàn)請求自動重試通常遵循以下五個步驟:
- 導(dǎo)入必需模塊:引入
requests
庫及其內(nèi)部組件,同時包含urllib3
的Retry
類。 - 創(chuàng)建HTTPAdapter實(shí)例:初始化一個
HTTPAdapter
對象,它是自定義請求適配器。 - 配置Retry策略:在
HTTPAdapter
上定義并設(shè)置重試規(guī)則,包括重試次數(shù)、狀態(tài)碼范圍、異常類型等條件。 - 將Adapter掛載到Session:將配置好的重試策略關(guān)聯(lián)到
Session
對象,以便所有通過該Session
發(fā)出的請求均能應(yīng)用此重試策略。 - 使用帶有重試策略的Session發(fā)送請求:最后,利用配置了重試功能的
Session
對象執(zhí)行實(shí)際的HTTP請求。
3. 使用urllib3實(shí)現(xiàn)重試邏輯
接下來通過具體示例詳細(xì)說明如何為requests
請求添加重試邏輯。
3.1. 導(dǎo)入相關(guān)模塊
首先,確保正確導(dǎo)入所需的庫和類。
import requests from requests.adapters import HTTPAdapter from urllib3.util.retry import Retry
3.2. 配置重試策略
利用Retry
類定義一個自定義的重試策略,可以針對重試次數(shù)、指數(shù)退避因子、特定狀態(tài)碼列表以及允許重試的HTTP方法進(jìn)行精確控制。
# 定義重試策略,例如:總共重試5次,每次重試之間按指數(shù)退避,針對特定狀態(tài)碼進(jìn)行重試,并僅限于GET和POST方法 retries = Retry( total=5, # 總共嘗試重試次數(shù) backoff_factor=1, # 指數(shù)退避因子,用于計(jì)算兩次重試之間的等待時間 status_forcelist=[500, 502, 503, 504], # 觸發(fā)重試的狀態(tài)碼集合 allowed_methods=frozenset(["GET", "POST"]), # 允許重試的HTTP方法 )
3.3. 創(chuàng)建HTTPAdapter并設(shè)置重試策略
創(chuàng)建一個HTTPAdapter
實(shí)例,并為其配置前面定義好的重試策略。
1adapter = HTTPAdapter(max_retries=retries) # 創(chuàng)建HTTPAdapter并設(shè)置最大重試次數(shù)
3.4. 將Adapter掛載至Session
創(chuàng)建一個Session
對象,并將上述已配置好重試策略的adapter
應(yīng)用于HTTP和HTTPS協(xié)議的請求。
session = requests.Session() session.mount('http://', adapter) # 對HTTP請求啟用重試策略 session.mount('https://', adapter) # 對HTTPS請求啟用重試策略
3.5. 發(fā)送具有重試功能的請求
使用配置了重試策略的session
對象向目標(biāo)URL發(fā)起請求。
url = "http://httpbin.org/status/500" response = session.get(url) # 使用具有重試功能的Session對象發(fā)送請求
4. 示例:請求一個可能返回錯誤的服務(wù)
以下是一個完整的示例,其中包含了錯誤處理機(jī)制:
import requests from requests.adapters import HTTPAdapter from urllib3.util.retry import Retry def request_with_retry(url, max_retries=5, backoff_factor=1, status_forcelist=None): if status_forcelist is None: status_forcelist = [500, 502, 503, 504] # 默認(rèn)重試狀態(tài)碼集合 session = requests.Session() retries = Retry(total=max_retries, backoff_factor=backoff_factor, status_forcelist=status_forcelist, method_whitelist=["GET", "POST"]) adapter = HTTPAdapter(max_retries=retries) session.mount('http://', adapter) session.mount('https://', adapter) try: response = session.get(url) response.raise_for_status() # 如果響應(yīng)狀態(tài)碼為4XX或5XX,將拋出HTTPError異常 return response except requests.exceptions.HTTPError as e: print(f"HTTP 錯誤: {e}") except requests.exceptions.ConnectionError as e: print(f"連接錯誤: {e}") except requests.exceptions.Timeout as e: print(f"超時錯誤: {e}") except requests.exceptions.RequestException as e: print(f"請求異常: {e}") url = "http://httpbin.org/status/500" response = request_with_retry(url) if response: print(response.text)
在上述示例中,當(dāng)服務(wù)返回500系列錯誤或是發(fā)生連接異常時,request_with_retry
函數(shù)將按照預(yù)設(shè)的最大重試次數(shù)(默認(rèn)為5次)嘗試重新發(fā)起請求。
結(jié)論
結(jié)合Python的requests
庫與urllib3
的Retry
類,我們可以輕松實(shí)現(xiàn)HTTP請求的自動重試機(jī)制,從而顯著增強(qiáng)應(yīng)用程序應(yīng)對網(wǎng)絡(luò)波動的能力。
特別是在微服務(wù)架構(gòu)、API調(diào)用等場景下,這一策略尤為關(guān)鍵。然而,務(wù)必注意合理設(shè)定重試次數(shù)和策略,避免過度重試導(dǎo)致服務(wù)器負(fù)載過大。
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Matplotlib scatter繪制散點(diǎn)圖的方法實(shí)現(xiàn)
這篇文章主要介紹了Matplotlib scatter繪制散點(diǎn)圖的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01Python實(shí)現(xiàn)的批量修改文件后綴名操作示例
這篇文章主要介紹了Python實(shí)現(xiàn)的批量修改文件后綴名操作,涉及Python目錄文件的遍歷、重命名等相關(guān)操作技巧,需要的朋友可以參考下2018-12-12Python如何處理大數(shù)據(jù)?3個技巧效率提升攻略(推薦)
這篇文章主要介紹了Python如何處理大數(shù)據(jù)?3個技巧效率提升攻略,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04手把手教會你雙目攝像頭Matlab參數(shù)定標(biāo)
雙目標(biāo)定是立體視覺系統(tǒng)中的一個關(guān)鍵步驟,下面這篇文章主要給大家介紹了關(guān)于雙目攝像頭Matlab參數(shù)定標(biāo)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07解決Python import .pyd 可能遇到路徑的問題
這篇文章主要介紹了解決Python import .pyd 可能遇到路徑的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03python 讀入多行數(shù)據(jù)的實(shí)例
下面小編就為大家分享一篇python 讀入多行數(shù)據(jù)的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04