Soenneker.Utils.RateLimiting.Executor 3.0.58

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.58                
NuGet\Install-Package Soenneker.Utils.RateLimiting.Executor -Version 3.0.58                
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.58" />                
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.58                
#r "nuget: Soenneker.Utils.RateLimiting.Executor, 3.0.58"                
#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.58

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

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.65 0 12/1/2024
3.0.64 0 12/1/2024
3.0.63 50 11/29/2024
3.0.62 69 11/29/2024
3.0.61 168 11/21/2024
3.0.60 85 11/21/2024
3.0.59 235 11/20/2024
3.0.58 71 11/20/2024
3.0.57 97 11/20/2024
3.0.56 74 11/20/2024
3.0.55 76 11/20/2024
3.0.54 88 11/20/2024
3.0.53 83 11/19/2024
3.0.52 70 11/19/2024
3.0.51 68 11/19/2024
3.0.50 359 11/19/2024
3.0.49 65 11/19/2024
3.0.48 280 11/19/2024
3.0.47 70 11/19/2024
3.0.46 68 11/19/2024
3.0.45 267 11/15/2024
3.0.44 115 11/14/2024
3.0.43 67 11/14/2024
3.0.42 65 11/14/2024
3.0.41 115 11/14/2024
3.0.40 81 11/14/2024
3.0.39 193 11/14/2024
3.0.38 288 11/14/2024
3.0.37 131 11/14/2024
3.0.36 66 11/14/2024
3.0.35 68 11/14/2024
3.0.34 113 11/14/2024
3.0.33 69 11/14/2024
3.0.32 166 11/14/2024
2.1.31 270 11/13/2024
2.1.30 155 11/13/2024
2.1.29 231 11/13/2024
2.1.28 122 11/12/2024
2.1.27 65 11/12/2024
2.1.26 534 11/9/2024
2.1.25 155 11/9/2024
2.1.24 317 11/8/2024
2.1.23 75 11/8/2024
2.1.22 72 11/8/2024
2.1.21 266 11/8/2024
2.1.20 210 11/8/2024
2.1.19 231 11/6/2024
2.1.18 308 11/1/2024
2.1.17 70 11/1/2024
2.1.16 298 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