利用分布式锁在ASP.NET Core中实现防抖

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 【9月更文挑战第5天】在 ASP.NET Core 中,可通过分布式锁实现防抖功能,仅处理连续相同请求中的首个请求,其余请求返回 204 No Content,直至锁释放。具体步骤包括:安装分布式锁库如 `StackExchange.Redis`;创建分布式锁服务接口及其实现;构建防抖中间件;并在 `Startup.cs` 中注册相关服务和中间件。这一机制有效避免了短时间内重复操作的问题。

ASP.NET Core 中,可以利用分布式锁来实现防抖功能。防抖是一种在短时间内连续触发事件时,只在最后一次触发后执行相应操作的技术。以下是具体的实现步骤:


一、准备工作


  1. 确保已经安装了合适的分布式锁库,比如StackExchange.Redis,用于与 Redis 实现分布式锁。可以通过 NuGet 包管理器进行安装。


二、创建分布式锁服务接口和实现


  1. 定义分布式锁服务接口:


public interface IDistributedLockService
   {
       IDisposable AcquireLock(string key);
   }


  1. 实现分布式锁服务:


public class RedisDistributedLockService : IDistributedLockService
   {
       private readonly IDatabase _database;
       public RedisDistributedLockService()
       {
           var redisConnection = ConnectionMultiplexer.Connect("your_redis_connection_string");
           _database = redisConnection.GetDatabase();
       }
       public IDisposable AcquireLock(string key)
       {
           var lockValue = Guid.NewGuid().ToString();
           var acquired = _database.LockTake(key, lockValue, TimeSpan.FromSeconds(30));
           if (acquired)
           {
               return new RedisLockDisposer(_database, key, lockValue);
           }
           else
           {
               return null;
           }
       }
       private class RedisLockDisposer : IDisposable
       {
           private readonly IDatabase _database;
           private readonly string _key;
           private readonly string _lockValue;
           public RedisLockDisposer(IDatabase database, string key, string lockValue)
           {
               _database = database;
               _key = key;
               _lockValue = lockValue;
           }
           public void Dispose()
           {
               _database.LockRelease(_key, _lockValue);
           }
       }
   }


三、创建防抖中间件


  1. 创建防抖中间件类:


public class DebounceMiddleware
   {
       private readonly RequestDelegate _next;
       private readonly IDistributedLockService _lockService;
       public DebounceMiddleware(RequestDelegate next, IDistributedLockService lockService)
       {
           _next = next;
           _lockService = lockService;
       }
       public async Task Invoke(HttpContext context)
       {
           var lockKey = "debounce_key_" + context.Request.Path;
           using var lock = _lockService.AcquireLock(lockKey);
           if (lock!= null)
           {
               await _next(context);
           }
           else
           {
               context.Response.StatusCode = StatusCodes.Status204NoContent;
           }
       }
   }


四、注册中间件和服务


  1. Startup.cs文件的ConfigureServices方法中注册分布式锁服务:


public void ConfigureServices(IServiceCollection services)
   {
       services.AddScoped<IDistributedLockService, RedisDistributedLockService>();
       // 其他服务注册...
   }


  1. Startup.cs文件的Configure方法中注册防抖中间件:


public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
   {
       app.UseMiddleware<DebounceMiddleware>();
       // 其他中间件注册...
   }


通过以上步骤,在 ASP.NET Core 应用中,当有连续的相同请求到达时,只有第一个请求会被处理,后续请求会立即返回 204 No Content 状态码,直到第一个请求处理完成并释放分布式锁。这样就实现了防抖功能,避免了在短时间内重复执行相同的操作。

相关文章
|
10月前
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
233 5
|
存储 开发框架 JSON
ASP.NET Core OData 9 正式发布
【10月更文挑战第8天】Microsoft 在 2024 年 8 月 30 日宣布推出 ASP.NET Core OData 9,此版本与 .NET 8 的 OData 库保持一致,改进了数据编码以符合 OData 规范,并放弃了对旧版 .NET Framework 的支持,仅支持 .NET 8 及更高版本。新版本引入了更快的 JSON 编写器 `System.Text.UTF8JsonWriter`,优化了内存使用和序列化速度。
225 0
|
11月前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
214 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
10月前
|
开发框架 算法 中间件
ASP.NET Core 中的速率限制中间件
在ASP.NET Core中,速率限制中间件用于控制客户端请求速率,防止服务器过载并提高安全性。通过`AddRateLimiter`注册服务,并配置不同策略如固定窗口、滑动窗口、令牌桶和并发限制。这些策略可在全局、控制器或动作级别应用,支持自定义响应处理。使用中间件`UseRateLimiter`启用限流功能,并可通过属性禁用特定控制器或动作的限流。这有助于有效保护API免受滥用和过载。 欢迎关注我的公众号:Net分享 (239字符)
193 1
|
10月前
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
239 3
mcr.microsoft.com/dotnet/core/aspnet:2.1安装libgdiplus
mcr.microsoft.com/dotnet/core/aspnet:2.1安装libgdiplus
86 1
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
183 3
|
12月前
|
开发框架 JavaScript 前端开发
一个适用于 ASP.NET Core 的轻量级插件框架
一个适用于 ASP.NET Core 的轻量级插件框架
171 0
|
开发框架 前端开发 .NET
ASP.NET Core 核心特性学习笔记「下」
ASP.NET Core 核心特性学习笔记「下」
|
开发框架 前端开发 中间件
ASP.NET Core 核心特性学习笔记「上」
ASP.NET Core 核心特性学习笔记「上」