标签:__ count retry return Python 实例 error 装饰 def
retry
偶然看到一篇文章,想到了前几天的一个需求,git pull
性能不稳,需要加入重试机制,正好这个装饰器的实例符合这样的场景。
# coding:utf-8
import time
import logging
import socket
from functools import wraps
logging.basicConfig(level=logging.DEBUG)
def retry(retries=3, delay=1):
def wrapper(func):
@wraps(func)
def proxy(*args, **kwargs):
count = retries
error = None
while count > 0:
try:
return func(*args, **kwargs)
except Exception as e:
print("relay times: {}".format(count))
count -= 1
time.sleep(delay)
error = e
print(u"have retry {} times, but happen error: {}".format(count, error))
return error
return proxy
return wrapper
@retry(2, 3)
def check():
sk = socket.socket()
sk.settimeout(5)
sk.connect(('x.x.x.x', 80))
'''
# 上面写法属于简写方式,等价于下面的处理
maketry=retry(2,3)
@maketry
def check():
pass
'''
if __name__ == "__main__":
check()
print(check.__name__)
参考:
- CSDN-郭 璞偶遇不错的装饰器:本文主要参考,但是该文示例有点小 bug,进一步优化了一下
- SOF-UnboundLocalError: local variable 'e' referenced before assignment:这个问题解决了上面遇到的 bug ,
try...except
的机制,会有一个特殊的作用域的处理,会del e
- Python之旅-装饰器:复习了一下带参数装饰器的写法,本文就属于带参数的装饰器的用法
标签:__,count,retry,return,Python,实例,error,装饰,def 来源: https://www.cnblogs.com/michael-xiang/p/10466814.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。