在.NET Core应用程序中使用Polly实现重试模式
在开发健壮的应用程序时,处理由于网络问题、服务不可用或其他间歇性问题而可能发生的暂时性故障至关重要。重试模式是一种可靠的方法,通过自动重新尝试失败的操作次数,直到成功或指定的超时,来解决这些暂时性故障。本文探讨如何在 .NET Core 应用程序中使用 Polly(一个 .NET 弹性和暂时性故障处理库)实现重试模式。它将深入探讨 Retry 模式及其优点、Polly 简介以及其实现的详细演练。了解重试模式重试模式是一种容错机制,它通过重新执行指定次数的失败操作来帮助处理暂时性故障。此方法使开发人员能够通过重试操作而不是立即声明失败来管理临时故障,例如网络超时或间歇性服务故障。
在开发健壮的应用程序时,处理由于网络问题、服务不可用或其他间歇性问题而可能发生的暂时性故障至关重要。重试模式是一种可靠的方法,通过自动重新尝试失败的操作次数,直到成功或指定的超时,来解决这些暂时性故障。
本文探讨如何在 .NET Core 应用程序中使用 Polly(一个 .NET 弹性和暂时性故障处理库)实现重试模式。它将深入探讨 Retry 模式及其优点、Polly 简介以及其实现的详细演练。
了解重试模式
重试模式是一种容错机制,它通过重新执行指定次数的失败操作来帮助处理暂时性故障。此方法使开发人员能够通过重试操作而不是立即声明失败来管理临时故障,例如网络超时或间歇性服务故障。
例如,假设其中一个微服务遇到内存过载问题或其他问题,导致其停机。我们可以选择尝试以特定的延迟重试,或者决定在重新启动微服务之前不重试。这种方法使我们能够有效地处理停机时间问题。还有更多真实的例子,我们可以在其中使用重试模式。
为什么重试模式很重要?
在当今的应用程序和系统中,可能会发生小问题或网络问题。这些故障可能会破坏事物的运作方式。为了保持事情顺利进行,重试模式有很大帮助。这就像一个备份计划,即使存在一些问题,也能确保事情继续运行。
处理暂时性故障:通过自动重试失败的操作来解决网络故障或资源不可用等临时故障。
提高可靠性: 允许应用程序从瞬时中断中恢复,而无需人工干预,从而提高系统弹性。
改善用户体验: 保护用户免于遇到错误,在应用程序中提供更流畅、不间断的体验。
主动故障处理: 主动处理潜在的瞬态故障,增强系统的整体弹性和可靠性。
自适应响应:可配置的重试策略可适应不同的服务可用性,从而优化操作完成。
减少停机时间: 通过持续出现暂时性故障来防止运营中断,从而为用户保持服务可用性。
什么是Polly?
Polly 是一个 .NET 弹性和暂时性故障处理库,允许开发人员表达策略(如重试、断路器和超时),以流畅且线程安全的方式处理故障。它提供了一种简单的声明性方法来定义和执行这些策略,以提高应用程序的可靠性。
可以使用以下命令通过 NuGet 包管理器或包管理器控制台将 Polly 安装在 .NET Core Web 应用程序中:
dotnet add package Polly
在 .NET Core 应用程序中使用 Polly 实现重试模式
下面是使用 Polly 在 .NET Core Web App 中实现重试策略的简化示例:
var httpClient = new HttpClient();
var retryPolicy = Policy
.Handle<HttpRequestException>()
.WaitAndRetryAsync(
retryCount: 3,
sleepDurationProvider: retryAttempt => TimeSpan.FromSeconds(15),
onRetryAsync: async (exception, timespan, retryAttempt, context) =>
{
Console.WriteLine($"Retry attempt {retryAttempt} after {timespan.TotalSeconds} seconds due to: {exception.Message}");
});
// Apply the retry policy to an API call
var result = await retryPolicy.ExecuteAsync(async () =>
{
var response = await httpClient.GetAsync("https://example.api.com/example-data");
// Check if the request was successful
response.EnsureSuccessStatusCode();
// Process the response if successful
var content = await response.Content.ReadAsStringAsync();
return content;
});
在此方案中,代码片段演示了如何在 .NET Core 应用程序设置中使用 Polly 中的方法实现重试模式。它首先设置一个来执行 API 请求。然后,使用 Polly 的方法定义重试策略。此策略指定,如果发生请求(通常是由于网络问题或 API 不可用等问题),系统应重试请求最多三次,每次尝试之间的固定延迟为 15 秒。
例如,我们正在使用此 API,但它未托管。在这种情况下,应在固定延迟内自动重试 3 次。
这演示了 Polly 如何积极简化 .NET Core Web 应用中重试等弹性策略的集成,使系统能够正常管理暂时性故障,并增强其针对 API 通信中间歇性问题的复原能力。
指数退避策略
指数回退是一种重试策略,每次尝试后,重试之间的延迟呈指数增加。它旨在防止因连续请求过多而使失败的资源不堪重负。
var retryPolicy = Policy
.Handle<HttpRequestException>()
.WaitAndRetryAsync(
retryCount: 3,
sleepDurationProvider: retryAttempt => TimeSpan.FromSeconds(Math.Pow(2, retryAttempt)),
onRetryAsync: async (exception, timespan, retryAttempt, context) =>
{
Console.WriteLine($"Retry attempt {retryAttempt} after {timespan.TotalSeconds} seconds due to: {exception.Message}");
});
在指数退避策略示例中,重试之间的延迟呈指数增长。在这里,睡眠持续时间是使用 计算的。该变量指示当前尝试次数,延迟根据该次数呈指数增加。TimeSpan.FromSeconds(Math.Pow(2, retryAttempt))retryAttempt
通过采用指数退避,系统引入了递增的延迟,这可以更有效地减少故障资源的负载,并在后续重试之前留出更多时间进行恢复,从而可能提高请求成功的机会。
在处理暂时性故障和重试时,选择最适合应用程序需求和资源限制的策略。
何时使用重试模式
网络运营:重试模式适用于处理可能发生超时或连接问题等暂时性故障的网络相关操作。 外部服务电话:在与可能遇到间歇性故障的外部服务集成时,它非常有用。何时不使用重试模式
非幂等运算:避免将重试用于非幂等操作(例如,修改数据的操作),因为它可能会导致多次重试的意外副作用。 非暂时性故障:在处理永久性或不可恢复的故障时,重试可能会加剧问题。在 .NET Core Web 应用程序中使用 Polly 实现重试模式可通过正常处理暂时性故障来增强应用程序的复原能力。Polly 的简单性和可配置性使其成为管理故障处理策略的强大工具,从而提高了应用程序在面对间歇性故障时的可靠性。了解何时应用重试以及何时避免重试对于在不同方案中有效利用其优势至关重要。
更新于:6个月前相关文章
- .NET C#中的Func、Predicate和Expression用法详解
- 5个高性能 .NET Core 图片处理库推荐
- ASP.NET如何将Views文件夹从项目分离
- .NET C# 读取编辑.AVIF图片文件
- .NET C# SkiaSharp读取.AVIF图片文件报错
- .NET开源ORM FreeSql常见问题和解决方法
- 微软于发布了.NET 9 Release Candidate 2 提高整体质量
- 分享5个开源的.NET Excel读写操作库
- .Net Core中Dapper的使用详解
- ASP.NET 使用Entity Framework (EF) 创建迁移修改SQLite数据库表结构
- 如何从.NET Framework迁移到.NET Core或.NET 6/7?
- 如何优化ASP.NET Core应用的性能?
- 10款.NET开发中推荐的代码分析和质量工具
- .NET9 Blazor有哪些更新?
- 在Docker、Kubernetes环境下部署.NET应用的最佳实践
- .NET 游戏开发框架有哪些?
- PluginCore 基于 ASP.NET Core 的轻量级插件框架
- .NET C# EntityFramework(EF)连接SQLite代码示例
- Sylvan.Data.Excel 性能优异的开源.NET Excel数据读取库
- ASP.NET Core 中常用的内置中间件