Redis EVALSHA命令

yizhihongxing

Redis的EVALSHA命令是一个用来执行Lua脚本的命令。相比于EVAL命令,EVALSHA命令的执行速度更快,且可以避免在脚本较长时因为传输脚本内容而导致的网络延迟。

使用方法

EVALSHA命令的语法如下:

EVALSHA script_sha1 numkeys key [key ...] arg [arg ...]

其中,script_sha1是指已经在Redis缓存中保存的Lua脚本的sha1值,numkeys代表脚本中使用到的key的个数,key是被Lua脚本使用到的键名,arg是传入到Lua脚本中使用的值。

实例说明

实例1:

假设我们有一个Lua脚本,在Redis的缓存中的sha1值为"926f32424d69b205b297296e4f7f3361d011d185",脚本内容如下:

local name = KEYS[1] 
local age = ARGV[1] 
redis.call('SET', name, age) 
return redis.call('GET', name)

接下来快速运行一下上述脚本,将值写入缓存中:

> EVAL "local name = 'Tom' local age = 20 redis.call('SET', name, age) return redis.call('GET', name)" 0

接下来我们可以使用EVALSHA命令来实现同样的逻辑:

> EVALSHA "926f32424d69b205b297296e4f7f3361d011d185" 1 Tom 20

经过测试,两个命令都可以正确地将值写入缓存中。

实例2:

继续考虑另一个Lua脚本,脚本内容如下:

if tonumber(redis.call('GET', KEYS[1])) > tonumber(ARGV[1])
then
    redis.call('SET', KEYS[1], ARGV[1]) 
    return 1
else
    return 0 
end

基于以上脚本内容,我们可以使用EVALSHA命令来实现原来的脚本内容,而不用再次传输完整的脚本内容:

> EVALSHA "3618e63f85c0421efb015067f99b1d528ec7be50" 1 test 10
(integer) 1
> EVALSHA "3618e63f85c0421efb015067f99b1d528ec7be50" 1 test 11
(integer) 0

以上命令分别比较test的值,如果值为10,则将其更新为11,并返回1;否则返回0。这在Redis缓存中的使用场景比较多见。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Redis EVALSHA命令 - Python技术站

(0)
上一篇 2023年3月27日
下一篇 2023年3月27日

相关文章

  • GO实现Redis:GO实现TCP服务器(1)

    本文实现一个Echo TCP Server interface/tcp/Handler.go type Handler interface { Handle(ctx context.Context, conn net.Conn) Close() error } Handler:业务逻辑的处理接口 Handle(ctx context.Context, con…

    2023年4月10日
    00
  • Redis避坑指南:为什么要有分布式锁?

    JUC提供的锁机制,可以保证在同一个JVM进程中同一时刻只有一个线程执行操作逻辑; 多服务多节点的情况下,就意味着有多个JVM进程,要做到这样,就需要有一个中间人; 分布式锁就是用来保证在同一时刻,仅有一个JVM进程中的一个线程在执行操作逻辑; 换句话说,JUC的锁和分布式锁都是一种保护系统资源的措施。尽可能将并发带来的不确定性转换为同步的确定性; 作者:京…

    2023年4月9日
    00
  • 面试官问你redis是单线程还是多线程该怎么回答?

    近乎所有与Java相关的面试都会问到缓存的问题,基础一点的会问到redis数据格式、什么是“热数据和冷数据”,复杂一点的会问到缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题,这些看似不常见的概念,都与我们的缓存服务器相关,一般常用的缓存服务器有Redis、Memcached等,就redis单线程,这篇文章做一个简单介绍 Redis采用的是基于内存的采…

    Redis 2023年4月12日
    00
  • redis能保证数据100%不丢失吗?

           我们都知道 Redis 的数据全部在内存里,如果突然宕机,数据就会全部丢失,因此必须有一种机制来保证 Redis 的数据不会因为故障而丢失,这种机制就是 Redis 的持久化机制。         众所周知,Redis 的持久化机制有两种,第一种是快照RDB,第二种是 AOF 日志。快照是一次全量备份,AOF 日志是连续的增量备份。快照是内存数…

    Redis 2023年4月12日
    00
  • redis宕机处理方案

    最简单防止数据丢失   搭集群: 分n组  每组有两个机器 主机和备机   心跳检测:每隔一段时间备机会ping一下主机  主机回一个pong   容灾:主机数据同步给备机   扩容:redis中槽范围0-16383,一共是16384个槽,将这些槽分给对应组机器   负载均衡:redis会将key使用crc16索法进行计算.会得出一个纯数字的值余数落到那个s…

    Redis 2023年4月12日
    00
  • redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool at redis.clients.util.Pool.getResource(Pool.java:53)

    解决方法1: 主要就是要去redis的配置文件中修改密码,修改完密码后记得重启redis。跟着作者的步骤走,可以完美解决! 解决方法2: 在配置文件中把password去除一样可以解决! 1.把redis配置文件中的password注释了 2.把spring-redis中的passwrod配置也注释了   参考:https://blog.csdn.net/i…

    Redis 2023年4月12日
    00
  • SpringBoot+Redis(实现处理热点数据)

    一、什么是热点数据 在很短的时间内,许多数据要被多次查询(像双十一购物,查询商品) 二、为什么要使用redis redis是非关系型数据库,Redis将数据存储在内存上,避免了频繁的IO操作,接下来,让大家正真感受下redis的魅力 三、场景 短时间内有大量的请求来获取用户列表的数据,每次都需要从数据库进行查询 1、原思路 技术:SpringBoot+mys…

    Redis 2023年4月13日
    00
  • redis持久化错误

    今天重启游戏服务器在连接redis数据库时突然报错:MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk. Commands that may modify the data set are disabled, be…

    Redis 2023年4月11日
    00
合作推广
合作推广
分享本页
返回顶部