Polly善用Context来记录异常发生时的参数信息

2024-02-01 07:48

本文主要是介绍Polly善用Context来记录异常发生时的参数信息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Polly是一个.NET弹性和瞬态故障处理库,具体用法可以参考:https://github.com/App-vNext/Polly,此处不会细讲如何使用Polly来进行异常处理或重试,就如标题所说,本篇内容主要为异常发生时除了Exception,又如何获取记录发生异常时你可能关心的数据信息

可能你们会觉得这么简单的问题有什么好说的,直接在方法内try catch记录后,再throw不就行了?当然这的确是一个实际的方法,但作为一个有追求的码农,每个Policy执行的方法都写一段try catch来进行日志记录,这么low的行为,实在……

好像废话多了,直奔主题吧,在使用Polly的时候,我们可以注意到所有的Policy都具备一个叫onXXX的委托,以RetryPolicy为例,在其所有重载方法中,一定会有最后一个参数叫onRetry的重载方法,该委托最多参数定义如下Action<Exception, TimeSpan, int, Context>,可见该委托包含了Exception发生的异常,然后还有一个重要参数就是Context,这个上下文在这里非常关键,还是以抽象类Policy的Execute方法为例,其重载方法除了包含带Context的Action外,本身也具备直接的Context参数,所以我们可以在对应Action中将请求参数传入Context,而Execute方法直接自带的Context则可以用来传入基础的参数,下面则是用于演示的demo代码

            //为方便测试,这里定义一个通用的委托,来模拟日志记录行为Action<Context,Exception, string> act = (c,e, s) =>{var color = Console.ForegroundColor;Console.ForegroundColor = ConsoleColor.Red;Console.WriteLine("LOG******{0}******LOG", s);foreach (var k in c.Keys)Console.WriteLine("Key:{0}  Value:{1}", k, c[k]);Console.ForegroundColor = ConsoleColor.Yellow;Console.WriteLine("Exception:{0}", e);//记录日志,这里日志就可以通过context来记录更精准的方法信息Console.ForegroundColor = color;};var fallBackPolicy = Policy.Handle<Exception>().Fallback((c, ct) => { }, (e, c) =>{//https://github.com/App-vNext/Polly/wiki/Fallbackact(c, e, string.Format("FallBack context contains keys:{0}", c.Keys.Count));});var timeoutPolicy = Policy.Timeout(5, Polly.Timeout.TimeoutStrategy.Pessimistic, (c, ts, t) =>{//https://github.com/App-vNext/Polly/wiki/Timeout//因为此处测试我们并没指定CancellationToken ,所以这里采取悲观策略act(c, new TimeoutException(), string.Format("Timeout context contains keys:{0}", c.Keys.Count));//Timeout比较特殊,因为异常不是发生在代码中,所以此处我们直接new了一个异常传入});fallBackPolicy.Execute(c =>{//因为timeout会产生异常,所以这里用FallBack包含下,不然后面的retryPolicy就无法执行了timeoutPolicy.Execute((ct) =>{Thread.Sleep(6000);}, new Dictionary<string, object> { { "Action", "timeoutPolicy" } });}, new Dictionary<string, object> { { "Action", "fallBackPolicy" } });var retryPolicy = Policy.Handle<Exception>().WaitAndRetry(5, (i, c) =>{//获取timespan的委托中,我们对context进行调整以进行测试Console.WriteLine("------------------");Console.WriteLine("Add key:{0} into context in sleepDurationProvider action", i);c.Add(i.ToString(), i.ToString());//c[i.ToString()] = i;//也可以直接这样进行赋值return TimeSpan.FromSeconds(5);}, (e, t, c) =>{act(c, e, string.Format("OnRetry context contains keys:{0}", c.Keys.Count));});retryPolicy.Execute(() =>{throw new Exception("just test");}, new Dictionary<string, object> { { "Action", "retryPolicy" } });

执行截图如下


这样,就可以将所有的异常统一进行log记录,而且log也包含了当前方法的相关参数信息

这篇关于Polly善用Context来记录异常发生时的参数信息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/666571

相关文章

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Java报NoClassDefFoundError异常的原因及解决

《Java报NoClassDefFoundError异常的原因及解决》在Java开发过程中,java.lang.NoClassDefFoundError是一个令人头疼的运行时错误,本文将深入探讨这一问... 目录一、问题分析二、报错原因三、解决思路四、常见场景及原因五、深入解决思路六、预http://www

一文带你深入了解Python中的GeneratorExit异常处理

《一文带你深入了解Python中的GeneratorExit异常处理》GeneratorExit是Python内置的异常,当生成器或协程被强制关闭时,Python解释器会向其发送这个异常,下面我们来看... 目录GeneratorExit:协程世界的死亡通知书什么是GeneratorExit实际中的问题案例

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定

Java捕获ThreadPoolExecutor内部线程异常的四种方法

《Java捕获ThreadPoolExecutor内部线程异常的四种方法》这篇文章主要为大家详细介绍了Java捕获ThreadPoolExecutor内部线程异常的四种方法,文中的示例代码讲解详细,感... 目录方案 1方案 2方案 3方案 4结论方案 1使用 execute + try-catch 记录

国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)

《国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)》本文给大家利用deepseek模型搭建私有知识问答库的详细步骤和遇到的问题及解决办法,感兴趣的朋友一起看看吧... 目录1. 第1步大家在安装完ollama后,需要到系统环境变量中添加两个变量2. 第3步 “在cmd中