RetrySharp 1.0.0
See the version list below for details.
dotnet add package RetrySharp --version 1.0.0
NuGet\Install-Package RetrySharp -Version 1.0.0
<PackageReference Include="RetrySharp" Version="1.0.0" />
<PackageVersion Include="RetrySharp" Version="1.0.0" />
<PackageReference Include="RetrySharp" />
paket add RetrySharp --version 1.0.0
#r "nuget: RetrySharp, 1.0.0"
#:package RetrySharp@1.0.0
#addin nuget:?package=RetrySharp&version=1.0.0
#tool nuget:?package=RetrySharp&version=1.0.0
RetrySharp
RetrySharp is a lightweight, high-performance retry utility for C# with zero external dependencies. Designed for systems where every microsecond and allocation matters.
Key Features
- Near-Zero Overhead: Optimized fast-path for non-retry scenarios.
- Zero Allocations: Target 0 allocations in synchronous hot paths.
- Sync & Async: Native support for both execution paths.
- Predictable: No hidden behavior or complex policy chaining.
- Minimalist: Tiny API surface (learnable in minutes).
Installation
dotnet add package RetrySharp
Usage
Basic Retry
Retries up to 3 times (default) if any exception occurs.
Retry.Execute(() => DoWork());
Async Retry with Cancellation
Supports CancellationToken and ConfigureAwait(false) internally.
await Retry.ExecuteAsync(async ct =>
{
await DoDownloadAsync(ct);
}, cancellationToken: cts.Token);
Exponential Backoff
Includes built-in strategies for fixed, linear, and exponential delays.
var options = new RetryOptions
{
MaxAttempts = 5,
DelayStrategy = RetryDelays.Exponential(
initialDelay: TimeSpan.FromMilliseconds(100),
maxDelay: TimeSpan.FromSeconds(2)
)
};
Retry.Execute(() => API.Call(), options);
Exception Filtering
Only retry for specific exception types.
var options = new RetryOptions
{
ExceptionFilter = ex => ex is HttpRequestException
};
Retry.Execute(() => SendRequest(), options);
Jitter and Observability
Add jitter to prevent "thundering herd" and hook into retry events.
var options = new RetryOptions
{
DelayStrategy = RetryDelays.WithJitter(RetryDelays.Fixed(TimeSpan.FromSeconds(1))),
OnRetry = ctx => Console.WriteLine($"Retry {ctx.Attempt} due to {ctx.Exception.Message}")
};
Retry.Execute(() => CriticalTask(), options);
Performance
RetrySharp is built for performance-critical applications:
- Fast-path optimization: When
MaxAttemptsis 1 and no extra options are set, the execution is a direct call with zero library overhead. - Struct-based context:
RetryContextis areadonly structto avoid heap allocations during callbacks. - Thread-safe: All delay strategies and jitter mechanisms are thread-safe.
License
Licensed under the MIT License.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Initial release of RetrySharp.
- Lightweight, high-performance retry utility.
- Sync and Async execution support.
- Built-in delay strategies: Fixed, Linear, Exponential, Jitter.
- Near-zero overhead for non-retry scenarios.
- Zero-allocation targets for sync paths.