使用Python装饰器的tenacity库实现异常重试机制
Python异常重试
如果某些方法需要重试,之前都是自己在except里写代码,很多时候实现起来并不方便,而且复杂逻辑下大大增加代码量和影响可读性,尝试了一下tenacity库,重试机制非常简单易用且清晰,且比retrying库简洁很多。
1,第一种常规方式,不借助第三方库,需要自行再except里写代码,真个方法显得十分臃肿
2,第二种方法使用tenacity库,实现起来非常优雅、轻便,当然tenacity库有非常强大的功能,有必要再探索。
demo一下数据库连接的异常重试实现,终于不用再自己写臃肿的重试逻辑了。
import time import psycopg2 import datetime from tenacity import * g_attempt = 0 # 直接再异常中进行代码的重试,需要一个global的变量做计数器, # 当方法执行发生异常后重试5次,每次间隔10秒 def my_retry_function_v1(conn): global g_attempt conn = None try: conn = psycopg2.connect(**conn) print('my_retry_function execute successfully') g_attempt = 0 except Exception as err: g_attempt = g_attempt + 1 if g_attempt <= 5: print(str(datetime.datetime.now()) + f' :retry---> {str(err)} ') print(f'retrying: {str(g_attempt)}') time.sleep(10) return my_retry_function_v1(conn) else: #记录异常,这里仅用print示例 print('sent a alert notification') if conn: return conn #方法执行发生异常后重试5次,每次间隔10秒 @retry(stop=stop_after_attempt(5), wait=wait_fixed(10)) def my_retry_function_v2(conn): conn = None try: conn = psycopg2.connect(**conn) print('my_retry_function execute successfully') except Exception as err: print(datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S.%f') + f' :retry---> {str(err)} ') #达到最大重试之后,记录异常信息 if (my_retry_function_v2.retry.statistics['attempt_number']) == 5: #记录异常,这里仅用print示例 print('sent a alert notification') else: #未超出最大重试次数之前,显式抛出异常,继续重试 raise if conn: return conn if __name__== '__main__': conn = {'host': '*', 'database': 'postgres', 'user': 'postgres', 'password': '*','port':*} my_retry_function_v1(conn)
分类:
Python
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
2019-08-03 MySQL集群读写分离的自定义实现