Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Redis的Lua

Redis的Lua

作者头像
名字是乱打的
发布于 2022-12-13 05:33:44
发布于 2022-12-13 05:33:44
32000
代码可运行
举报
文章被收录于专栏:软件工程软件工程
运行总次数:0
代码可运行

贴一个自己封装的通用lua执行器

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    /**
     * 通用lua脚本执行器
     *
     * @param luaStr  lua脚本
     * @param resType 返回值类型
     * @param keys    key值集合
     * @param args    参数类型集合
     * @return lua执行结果
     * @author zyh     */
    <T> T commonLuaExecute(String luaStr, Class<T> resType, List<String> keys, Object... args);

脚本

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 /**
     * 机会购下单lua
        hash 结构
        flide为用户id
        keys1 map的key
        keys2 是filte 用户id
        args1 是当前使用机会数
        args2 是总使用机会数
        value为购买次数(已使用机会数)
        totalChanceCount 活动设置的总机会数
        goodsCount 本次需要使用的机会数
     * @author zyh
     */
    public static final String LUA_ADD_BUY_RECORD_ADD_FOR_CHANCE =
            "local buyCount=tonumber(redis.call('Hget',KEYS[1],KEYS[2]));" +
                    "local goodsCount=tonumber(ARGV[1])" +
                    "local totalChanceCount=tonumber(ARGV[2])" +
                    " if (buyCount == nil) then " +
                    "   if(goodsCount<=totalChanceCount) then" +
                    "       redis.call('HINCRBY',KEYS[1],KEYS[2],goodsCount)" +
                    "       return 1;" +
                    "   else " +
                    "       return 0;" +
                    "   end" +
                    " else " +
                    "   if((goodsCount+buyCount)<=totalChanceCount) then" +
                    "       redis.call('HINCRBY',KEYS[1],KEYS[2],goodsCount)" +
                    "       return 1;" +
                    "   else " +
                    "       return 0;" +
                    "   end;" +
                    " end;";
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-12-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
redis 分布式锁的 5个坑,真是又大又深
最近项目上线的频率颇高,连着几天加班熬夜,身体有点吃不消精神也有些萎靡,无奈业务方催的紧,工期就在眼前只能硬着头皮上了。脑子浑浑噩噩的时候,写的就不能叫代码,可以直接叫做Bug。我就熬夜写了一个bug被骂惨了。
程序员小富
2020/04/22
2.3K0
使用Aop+Redis+lua限流,优化高并发问题
限流的方式有很多: 1、单机模式下,可以使用AtomicInteger、RateLimiter、Semaphore。 2、分布式下,可以使用队列(如Kafka等),但是编码比较繁杂;也可以使用Nginx限流,但是属于网关层面,不能解决所有问题(如内部服务接口)。 所以,应用层也是需要做限流操作的。这里简单结合Aop+redis+lua来实现。注:如果是需要接入层先流的话,建议还是要使用nginx自带的连接数限流模块和请求限流模块。 Lua脚本:
有一只柴犬
2024/01/25
2780
redis 读写锁实现
关于redis读写锁,我写了一次之后,总觉得很怪,然后就上网看到大神的redisson了,果断借鉴一番。
ydymz
2018/12/27
5.9K0
深入理解 Redis Lua 脚本调试技巧和最佳实践
Redis Lua 脚本调试是一种强大的工具,可以帮助您快速发现和解决Lua脚本中的问题。它允许您在运行脚本时逐步执行脚本,并检查每个步骤的结果。
Tinywan
2024/01/10
1.2K0
深入理解 Redis Lua 脚本调试技巧和最佳实践
Redis 如何实现延时任务队列
顾名思义,延迟队列就是进入该队列的消息会被延迟消费的队列。而一般的队列,消息一旦入队了之后就会被消费者马上消费。
Tinywan
2024/05/11
8540
Redis 如何实现延时任务队列
如何使用Redis实现电商系统的库存扣减?
在日常开发中有很多地方都有类似扣减库存的操作,比如电商系统中的商品库存,抽奖系统中的奖品库存等。
码农编程进阶笔记
2022/02/17
6620
Redis常用技术-----使用Lua语言
Redis命令的计算能力并不算很强大,使用Lua语言则可以在很大程度上弥补Redis的这个不足。在Redis中,执行Lua语言是原子性,也就是说Redis执行Lua的时候是不会被中断的,具备原子性,这个特性有助于Redis对并发数据一致性的支持。
秃头哥编程
2019/06/17
8890
Redis常用技术-----使用Lua语言
【分布式锁】02-使用Redisson实现公平锁原理
前面分析了Redisson可重入锁的原理,主要是通过lua脚本加锁及设置过期时间来保证锁执行的原子性,然后每个线程获取锁会将获取锁的次数+1,释放锁会将当前锁次数-1,如果为0则表示释放锁成功。
一枝花算不算浪漫
2020/03/21
3.7K0
使用Redis的几种线程安全的方式
我经常使用Redis,比如有一个常见的场景就是获取key的值,如果小于某个阈值,就加一并且将加一后的值重新set回redis,返回true,否则返回false。就这样简单额场景,其中也牵扯到线程安全的问题。
CBeann
2023/12/25
6210
Redis基础教程(十三):Redis lua脚本
Redis 脚本功能是Redis提供的一种强大工具,允许用户在服务器端执行Lua脚本,从而实现复杂的数据处理逻辑和业务规则。通过在Redis内部执行脚本,可以显著减少网络延迟,提高数据处理的效率和响应速度。本文将深入探讨Redis脚本的使用方法,并通过详细的实战案例展示如何利用Lua脚本来优化数据操作。
用户11147438
2024/07/12
1K0
高性能分布式限流:Redis+Lua真香!
限流,这个词其实并不陌生,在我们生活中也随处可见。做核酸时,工作人员会在核酸检测点的空地上摆放着弯弯曲曲的围栏,人们排着队左拐右拐的往前移动,其实这么做的目的就是限流!因为核酸检测的窗口是有限的,一下子进那么多人,没那么多空间让人们站下,就会造成拥挤,甚至会造成事故。所以需要限流!
编程大道
2023/03/17
2.9K0
高性能分布式限流:Redis+Lua真香!
【分布式锁】04-使用Redisson实现ReadWriteLock原理
关于读写锁,大家应该都了解JDK中的ReadWriteLock, 当然Redisson也有读写锁的实现。
一枝花算不算浪漫
2020/03/23
3K0
【分布式锁】04-使用Redisson实现ReadWriteLock原理
redis之初识lua脚本
Lua脚本特性的出现给Redis带来了很大的变化,其中最重要的就是使得用户可以按需对Redis服务器的功能进行扩展:在Lua脚本特性出现之前,用户如果想要给Redis服务器增加新功能,那么只能自行修改Redis服务器源码,这样做不仅麻烦,还会给Redis服务器带来升级困难、无法与标准Redis服务器兼容等问题,而Lua脚本的出现则为用户提供了一种标准的、无后顾之忧的方法来扩展Redis服务器的功能。
墨紫羽墨
2023/01/30
2.6K0
lua脚本-redis批量设置key并且带TTL-两种方案
KEYS: ["my:key:::1","my:key:::2","my:key:::3"]
王宝
2024/11/25
2180
用 Redis 做一个可靠的延迟队列
点击上方“芋道源码”,选择“设为星标” 管她前浪,还是后浪? 能浪的浪,才是好浪! 每天 10:33 更新文章,每天掉亿点点头发... 源码精品专栏 原创 | Java 2021 超神之路,很肝~ 中文详细注释的开源项目 RPC 框架 Dubbo 源码解析 网络应用框架 Netty 源码解析 消息中间件 RocketMQ 源码解析 数据库中间件 Sharding-JDBC 和 MyCAT 源码解析 作业调度中间件 Elastic-Job 源码解析 分布式事务中间件 TCC-Transaction
芋道源码
2022/07/19
4780
用 Redis 做一个可靠的延迟队列
Redis可重入锁的实现设计
但是仍然有些场景是不满⾜的,例如⼀ 个⽅法获取到锁之后,可能在⽅法内调这个⽅法此时就获取不到锁了。这个时候我们就需要把锁改进成可 重⼊锁了。 重⼊锁,指的是以线程为单位,当⼀个线程获取对象锁之后,这个线程可以再次获取本对象上的锁,⽽其 他的线程是不可以的。可重⼊锁的意义在于防⽌死锁。 实现原理是通过为每个锁关联⼀个请求计数器和⼀个占有它的线程。当计数为 0 时,认为锁是未被占有 的;线程请求⼀个未被占有的锁时,JVM 将记录锁的占有者,并且将请求计数器置为 1 。 如果同⼀个线程再次请求这个锁,计数将递增;每次占⽤线程退出同步块,计数器值将递减。直到计数器 为 0, 锁被释放。 关于⽗类和⼦类的锁的重⼊:⼦类覆写了⽗类的 synchonized ⽅法,然后调⽤⽗类中的⽅法,此时如果没有重⼊的锁,那么这段代码将产⽣死锁。
JavaEdge
2021/02/23
7740
Redis可重入锁的实现设计
Redis使用Lua脚本:保证原子性【项目案例分享】
本文主要分享2个项目里使用lua脚本的实战案例,主要使用lua脚本保证原子性. 在正式介绍项目案例之前,我们先对Lua脚本以及如何在Redis中使用有个基本的了解。
天罡gg
2022/12/02
1.3K0
Redis使用Lua脚本:保证原子性【项目案例分享】
Redis 实现多规则限流的思考与实践
市面上很多介绍redis如何实现限流的,但是大部分都有一个缺点,就是只能实现单一的限流,比如1分钟访问1次或者60分钟访问10次这种,但是如果想一个接口两种规则都需要满足呢,我们的项目又是分布式项目,应该如何解决,下面就介绍一下redis实现分布式多规则限流的方式。
架构精进之路
2024/01/08
6370
Redis 实现多规则限流的思考与实践
Redis入坟(二)高级特性,发布订阅、事务、Lua脚本
前面我们说通过队列的 rpush 和 lpop 可以实现消息队列(队尾进队头出),但是消费者需要不停地调用 lpop 查看 List 中是否有等待处理的消息(比如写一个 while 循环)。
源码之路
2020/09/04
9750
Redis入坟(二)高级特性,发布订阅、事务、Lua脚本
基于Redis和Lua的分布式限流
 Java单机限流可以使用AtomicInteger,RateLimiter或Semaphore来实现,但是上述方案都不支持集群限流。集群限流的应用场景有两个,一个是网关,常用的方案有Nginx限流和Spring Cloud Gateway,另一个场景是与外部或者下游服务接口的交互,因为接口限制必须进行限流。
程序员历小冰
2019/04/07
1.9K0
基于Redis和Lua的分布式限流
相关推荐
redis 分布式锁的 5个坑,真是又大又深
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验