python重試裝飾器的簡單實(shí)現(xiàn)方法
簡單實(shí)現(xiàn)了一個在函數(shù)執(zhí)行出現(xiàn)異常時自動重試的裝飾器,支持控制最多重試次數(shù),每次重試間隔,每次重試間隔時間遞增。
最新的代碼可以訪問從github上獲取
https://github.com/blackmatrix7/matrix-toolkit/blob/master/toolkit/retry.py
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2017/8/18 上午9:50
# @Author : Matrix
# @Github : https://github.com/blackmatrix7/
# @Blog : http://www.cnblogs.com/blackmatrix/
# @File : retry.py
# @Software: PyCharm
import time
from functools import wraps
__author__ = 'blackmatrix'
"""
在函數(shù)執(zhí)行出現(xiàn)異常時自動重試的簡單裝飾器
"""
class StopRetry(Exception):
def __repr__(self):
return 'retry stop'
def retry(max_retries: int =5, delay: (int, float) =0, step: (int, float) =0,
exceptions: (BaseException, tuple, list) =BaseException,
sleep=time.sleep, callback=None, validate=None):
"""
函數(shù)執(zhí)行出現(xiàn)異常時自動重試的簡單裝飾器。
:param max_retries: 最多重試次數(shù)。
:param delay: 每次重試的延遲,單位秒。
:param step: 每次重試后延遲遞增,單位秒。
:param exceptions: 觸發(fā)重試的異常類型,單個異常直接傳入異常類型,多個異常以tuple或list傳入。
:param sleep: 實(shí)現(xiàn)延遲的方法,默認(rèn)為time.sleep。
在一些異步框架,如tornado中,使用time.sleep會導(dǎo)致阻塞,可以傳入自定義的方法來實(shí)現(xiàn)延遲。
自定義方法函數(shù)簽名應(yīng)與time.sleep相同,接收一個參數(shù),為延遲執(zhí)行的時間。
:param callback: 回調(diào)函數(shù),函數(shù)簽名應(yīng)接收一個參數(shù),每次出現(xiàn)異常時,會將異常對象傳入。
可用于記錄異常日志,中斷重試等。
如回調(diào)函數(shù)正常執(zhí)行,并返回True,則表示告知重試裝飾器異常已經(jīng)處理,重試裝飾器終止重試,并且不會拋出任何異常。
如回調(diào)函數(shù)正常執(zhí)行,沒有返回值或返回除True以外的結(jié)果,則繼續(xù)重試。
如回調(diào)函數(shù)拋出異常,則終止重試,并將回調(diào)函數(shù)的異常拋出。
:param validate: 驗(yàn)證函數(shù),用于驗(yàn)證執(zhí)行結(jié)果,并確認(rèn)是否繼續(xù)重試。
函數(shù)簽名應(yīng)接收一個參數(shù),每次被裝飾的函數(shù)完成且未拋出任何異常時,調(diào)用驗(yàn)證函數(shù),將執(zhí)行的結(jié)果傳入。
如驗(yàn)證函數(shù)正常執(zhí)行,且返回False,則繼續(xù)重試,即使被裝飾的函數(shù)完成且未拋出任何異常。
如回調(diào)函數(shù)正常執(zhí)行,沒有返回值或返回除False以外的結(jié)果,則終止重試,并將函數(shù)執(zhí)行結(jié)果返回。
如驗(yàn)證函數(shù)拋出異常,且異常屬于被重試裝飾器捕獲的類型,則繼續(xù)重試。
如驗(yàn)證函數(shù)拋出異常,且異常不屬于被重試裝飾器捕獲的類型,則將驗(yàn)證函數(shù)的異常拋出。
:return: 被裝飾函數(shù)的執(zhí)行結(jié)果。
"""
def wrapper(func):
@wraps(func)
def _wrapper(*args, **kwargs):
nonlocal delay, step, max_retries
func_ex = StopRetry
while max_retries > 0:
try:
result = func(*args, **kwargs)
# 驗(yàn)證函數(shù)返回False時,表示告知裝飾器驗(yàn)證不通過,繼續(xù)重試
if callable(validate) and validate(result) is False:
continue
else:
return result
except exceptions as ex:
# 回調(diào)函數(shù)返回True時,表示告知裝飾器異常已經(jīng)處理,終止重試
if callable(callback) and callback(ex) is True:
return
func_ex = ex
finally:
max_retries -= 1
if delay > 0 or step > 0:
sleep(delay)
delay += step
else:
raise func_ex
return _wrapper
return wrapper
if __name__ == '__main__':
pass
以上這篇python重試裝飾器的簡單實(shí)現(xiàn)方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python 中創(chuàng)建 PostgreSQL 數(shù)據(jù)庫連接池
這篇文章主要介紹了Python 中創(chuàng)建 PostgreSQL 數(shù)據(jù)庫連接池,Python 連接 PostgreSQL 是主要有兩個包, py-postgresql 和 psycopg2 , 而本文的實(shí)例將使用后者,感興趣的小伙伴可以參考一下2021-10-10
Python獲取運(yùn)行目錄與當(dāng)前腳本目錄的方法
這篇文章主要介紹了Python獲取運(yùn)行目錄與當(dāng)前腳本目錄的方法,涉及Python目錄操作與系統(tǒng)相關(guān)變量的獲取技巧,需要的朋友可以參考下2015-06-06
Python+OpenCV 實(shí)現(xiàn)簡單的高斯濾波(推薦)
這篇文章主要介紹了Python+OpenCV 實(shí)現(xiàn)簡單的高斯濾波,在文中需要注意的是,這里我沒有特判當(dāng)sigma = 0的時候的情況,具體實(shí)現(xiàn)過程跟隨小編一起看看吧2021-09-09
Python實(shí)現(xiàn)繪制多種激活函數(shù)曲線詳解
所謂激活函數(shù)(Activation?Function),就是在人工神經(jīng)網(wǎng)絡(luò)的神經(jīng)元上運(yùn)行的函數(shù),負(fù)責(zé)將神經(jīng)元的輸入映射到輸出端。這篇文章主要介紹了Python如何實(shí)現(xiàn)繪制多種激活函數(shù)曲線,希望對大家有所幫助2023-04-04
python的dict,set,list,tuple應(yīng)用詳解
這篇文章主要介紹了python的dict,set,list,tuple應(yīng)用詳解,需要的朋友可以參考下2014-07-07

