架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

搜索
查看: 42328|回复: 2

[资料] .NET Core 基于 Redis Lua 实现分布式锁[附源码]

[复制链接]
发表于 2021-5-9 21:11:18 | 显示全部楼层 |阅读模式
分布式锁的应用场景:随着业务的发展,单体应用变成集群,分布式锁是解决并发情况下不同进程(线程)对同一个资源的操作,有些业务必须要求单线程进行操作,例子:存款金额的变化、商品库存的变化等。

回顾:

.NET Core 基于 Redis 实现分布式锁原理解析
https://www.itsvse.com/thread-9391-1-1.html

.net/c# Zookeeper分布式锁的实现[源码]
https://www.itsvse.com/thread-4651-1-1.html

Redis 使用 Lua 脚本详解
https://www.itsvse.com/thread-9634-1-1.html

【实战】ASP.NET Core 基于 Redis 分布式锁秒杀
https://www.itsvse.com/thread-9397-1-1.html

之前写的“【实战】ASP.NET Core 基于 Redis 分布式锁秒杀”文章中,我们在新增锁的时候,同时开启了一个后台线程取延长锁的时间,从而保证释放锁的时候,不会误删除别的线程占用的锁。

在学习了 Redis 使用 Lua 脚本后,直接可以很方便的使用脚本来完成占用锁和释放锁。


首先,先看效果图如下:

QQ截图20210509210119.jpg

我们先开了 1000 个并行的线程取争夺锁,锁的失效时间为 5 秒,我们在 5 秒内完成了 1000 个线程,只有 1 个线程成功获取到锁,等待 6 秒后,锁自动被释放,可以看到第二个 Task 成功获取到了锁,立马将锁释放后,后面的代码又成功获取到了锁。

获取锁的 lua 脚本如下:

释放锁的 lua 脚本如下:

接口代码:

源码下载:超链接登录可见。

修改“【实战】ASP.NET Core 基于 Redis 分布式锁秒杀”使用本文实现,我们网站模拟有 10000 件商品,然后写了一个控制台模拟HTTP请求用时 6 秒抢购完成,如下图:

【实战】ASP.NET Core 基于 Redis 分布式锁秒杀
https://www.itsvse.com/thread-9397-1-1.html

QQ截图20210509210419.jpg

修改测试模拟请求代码:



(完)




上一篇:Kafka 手动设置 offset 偏移量
下一篇:ASP.NET Core 获取请求完整 URL 链接
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2021-11-4 13:50:43 | 显示全部楼层
{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}{:1_1:}
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2022-6-11 13:36:33 | 显示全部楼层
感谢感谢
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2025-6-15 20:42

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表