Soenneker.Utils.RateLimiting.Executor 3.0.65

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package Soenneker.Utils.RateLimiting.Executor --version 3.0.65                
NuGet\Install-Package Soenneker.Utils.RateLimiting.Executor -Version 3.0.65                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Soenneker.Utils.RateLimiting.Executor" Version="3.0.65" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Soenneker.Utils.RateLimiting.Executor --version 3.0.65                
#r "nuget: Soenneker.Utils.RateLimiting.Executor, 3.0.65"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Soenneker.Utils.RateLimiting.Executor as a Cake Addin
#addin nuget:?package=Soenneker.Utils.RateLimiting.Executor&version=3.0.65

// Install Soenneker.Utils.RateLimiting.Executor as a Cake Tool
#tool nuget:?package=Soenneker.Utils.RateLimiting.Executor&version=3.0.65                

alternate text is missing from this package README image alternate text is missing from this package README image alternate text is missing from this package README image

alternate text is missing from this package README image Soenneker.Utils.RateLimiting.Executor

A thread-safe utility designed to manage the rate at which tasks are executed, ensuring they are not run more frequently than a specified interval.

RateLimitingExecutor is ideal for interacting with rate-limited APIs or throttling the execution of resource-intensive tasks.

Sequential Execution

Tasks, ValueTasks, and Actions are executed one at a time. If the defined interval between executions has passed, the task runs immediately; otherwise, it waits until the interval elapses before proceeding.

⚠️ Important Notes:

  • This is not a background queue processor. Each method awaits the result of the asynchronous operation before continuing.

  • Asynchronous methods will not block the calling thread, but synchronous methods will block execution until it completes.

Want to use this with dependency injection?

Check out the singleton factory implementation: Soenneker.Utils.RateLimiting.Factory

Installation

dotnet add package Soenneker.Utils.RateLimiting.Executor

Example: Executing a Loop of Tasks with Rate Limiting

Below is an example demonstrating how to use the RateLimitingExecutor to execute a series of tasks while maintaining a rate limit.

using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using Soenneker.Utils.RateLimiting.Executor;

public class Program
{
    public static async Task Main(string[] args)
    {
        var rateLimitingExecutor = new RateLimitingExecutor(TimeSpan.FromSeconds(2));

        for (int i = 0; i < 5; i++)
        {
            await rateLimitingExecutor.Execute(async ct =>
            {
                Console.WriteLine($"Executing Task {i + 1} at {DateTime.Now:HH:mm:ss}");
                await Task.Delay(100); // Simulate some work
            });
        }
    }
}

Console Output

Executing Task 1 at 14:00:00
Executing Task 2 at 14:00:02
Executing Task 3 at 14:00:04
Executing Task 4 at 14:00:06
Executing Task 5 at 14:00:08
Product Compatible and additional computed target framework versions.
.NET net9.0 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Soenneker.Utils.RateLimiting.Executor:

Package Downloads
Soenneker.Utils.RateLimiting.Factory

An async thread-safe singleton dictionary for Soenneker.Utils.RateLimiting.Executors, designed to manage the rate at which tasks are executed.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.0.72 0 12/2/2024
3.0.71 0 12/2/2024
3.0.70 25 12/2/2024
3.0.69 28 12/2/2024
3.0.68 49 12/2/2024
3.0.67 78 12/1/2024
3.0.66 34 12/1/2024
3.0.65 103 12/1/2024
3.0.64 47 12/1/2024
3.0.63 83 11/29/2024
3.0.62 71 11/29/2024
3.0.61 170 11/21/2024
3.0.60 87 11/21/2024
3.0.59 237 11/20/2024
3.0.58 73 11/20/2024
3.0.57 99 11/20/2024
3.0.56 76 11/20/2024
3.0.55 78 11/20/2024
3.0.54 90 11/20/2024
3.0.53 85 11/19/2024
3.0.52 72 11/19/2024
3.0.51 70 11/19/2024
3.0.50 361 11/19/2024
3.0.49 67 11/19/2024
3.0.48 282 11/19/2024
3.0.47 72 11/19/2024
3.0.46 70 11/19/2024
3.0.45 269 11/15/2024
3.0.44 117 11/14/2024
3.0.43 69 11/14/2024
3.0.42 67 11/14/2024
3.0.41 117 11/14/2024
3.0.40 83 11/14/2024
3.0.39 195 11/14/2024
3.0.38 290 11/14/2024
3.0.37 133 11/14/2024
3.0.36 68 11/14/2024
3.0.35 70 11/14/2024
3.0.34 115 11/14/2024
3.0.33 71 11/14/2024
3.0.32 168 11/14/2024
2.1.31 272 11/13/2024
2.1.30 161 11/13/2024
2.1.29 233 11/13/2024
2.1.28 124 11/12/2024
2.1.27 67 11/12/2024
2.1.26 536 11/9/2024
2.1.25 157 11/9/2024
2.1.24 319 11/8/2024
2.1.23 77 11/8/2024
2.1.22 74 11/8/2024
2.1.21 268 11/8/2024
2.1.20 212 11/8/2024
2.1.19 233 11/6/2024
2.1.18 310 11/1/2024
2.1.17 72 11/1/2024
2.1.16 300 11/1/2024
2.1.14 84 10/29/2024
2.1.13 235 10/29/2024
2.1.12 123 10/29/2024
2.1.11 392 10/29/2024
2.1.10 232 10/28/2024
2.1.9 68 10/28/2024
2.1.8 98 10/28/2024
2.1.7 333 10/26/2024
2.1.6 92 10/26/2024
2.1.5 240 10/22/2024
2.1.4 96 10/22/2024
2.1.3 73 10/22/2024
2.1.2 83 10/22/2024
2.1.1 99 10/22/2024