it编程 > 数据库 > Redis

Redis批量查询的四种方式详解

16人参与 2025-10-16 Redis

引言

在高并发场景下,巧妙地利用缓存批量查询技巧能够显著提高系统性能。

在笔者看来,熟练掌握细粒度的缓存使用是每位架构师必备的技能。因此,在本文中,我们将深入探讨 redis 中批量查询的一些技巧,希望能够给你带来一些启发。

图片

1.为什么需要批量执行命令

下图展示了客户端与服务端交互的流程:

图片

每次客户端发送一个一个请求命令,redis 服务端接收到命令后,将命令放在队列内,一个一个命令执行,并将结果返回。

批量执行命令有三点优势:

提高命令执行效率

简化客户端逻辑

提升事务性能

接下来,我们详细讲解批量查询的四种方式。

2.字符串 mget命令

mget 是 redis 中的一个命令,用于批量获取多个字符串键的值。它接受一个或多个键作为参数,返回与这些键关联的值。

以下是一个简要的描述:

图片

该命令主要用于一次性获取多个键的值,可以减少多次单独查询的开销,提高效率。

图片

接下来,我们展示 springboot 项目展示如何使用 mget 命令。

图片

图中,我们分别设置(key:a , b , c) 三个 key 的值,然后定义一个列表对象 keys, 列表中包含了一个不存在的键 "d"。

图片

当我们使用 multiget 命令查看结果时,发现返回的结果是一个列表对象,列表对象的大小是 4,同时第三个对象值为 null ,也就是键 “d” 对应的值为 nil

3.哈希表 hmget命令

hmget 是 redis 中的命令之一,用于获取哈希表中指定字段的值。

它接受一个哈希表的键以及一个或多个字段名作为参数,返回与这些字段名关联的值。以下是 hmget 命令的基本语法:

图片

如果给定的域不存在于哈希表,那么返回一个 nil 值。

因为不存在的 key 被当作一个空哈希表来处理,所以对一个不存在的 key 进行 hmget 操作将返回一个只带有 nil 值的表。

图片

接下来,我们展示 springboot 项目展示如何使用 hmget 命令。

图片

首先分别设置键为 "myhashkey" 下的三个字段(field)的值 ,然后定义需要查询的字段集合 fields ,最后调用哈希表的 hmget 命令。

图片

和 mget命令的结果类似,spring data redis 会将结果封装成 list 对象,列表对象的大小是 4,同时第三个对象值为 null ,因为字段 “d” 对应的值为 nil

4.管道技术

redis pipeline(管道)命令是一种优化网络通信的技术,可以将多个命令一次性发送给 redis 服务器,可以减少客户端与 redis 服务器之间的网络通信次数。

图片

客户端将多个命令一次性发送给 redis 服务器,redis 服务器缓存这些命令,并一次性执行,最后将执行结果一次性返回给客户端。

通过使用 redis pipeline,显而易见的好处是避免了在每个命令执行时都进行一次网络通信,从而显著降低了时间开销。

1 次 pipeline(n条命令) = 1 次网络时间 + 执行n 条命令时间

接下来,我们展示 springboot 项目展示如何使用 pipeline 管道命令。

图片

首先分别设置三个键(key:a, b, c)的值,然后分别设置键为 "myhashkey" 下的三个字段(field)的值, 最后调用 pipeline 执行多个命令,并获取结果。

图片

需要注意的是:

由于 redis cluster 采用的是分片机制,这些键无法保证所有的 key 都在同一区域的哈希槽上。因此,即使使用了 pipeline,每个命令仍可能在不同的节点上进行处理,导致多个命令的执行不在同一时刻。

不可以。如果 pipeline 中后一个命令的执行依赖于前一个命令的执行结果,pipeline 无法满足这样的需求。

虽然命令可以一次性发给 redis 服务端,但是考虑到带宽等情况,建议不要超过500个命令,或者根据实际命令的数据类型和大小进行调整。这样可以避免潜在的性能问题。

5.lua 脚本

redis lua 脚本是一种在 redis 服务器上执行的脚本语言,基于 lua 编程语言。

这种脚本可以包含多个 redis 命令,而且它们在 redis 服务器上以原子性操作的方式执行。通过使用 lua 脚本,你可以在服务器端执行一系列的 redis 命令,而不需要将它们一条一条地发送到服务器。

redis 执行 lua 脚本有两种执行方式:eval 和 evalsha 。

5.1 eval

图片

eval命令的执行过程主要可以分为三个步骤:

这个流程使得 redis 能够高效地处理客户端提供的 lua 脚本,同时通过缓存 sha1 校验和,可以减少重复传输脚本的开销,提高效率。

在redis中,使用了 key 列表和参数列表来为lua脚本提供更多的灵活性,执行 eval 命令的格式为:

图片

下图演示下 lua 如何调用 redis 命令 ,通过redis.call()来执行了 redis 命令 。

图片

5.2 evalsha

与 eval 不同,evalsha 的主要目的是通过脚本的 sha1 校验和来执行预先在服务器端加载的 lua 脚本,从而避免重复传输脚本的开销。

图片

使用步骤:

1、加载 lua 脚本到 redis 服务端:

首先,将 lua 脚本加载到 redis 服务端。这可以通过 script load 命令完成。执行 script load 后,会返回一个 sha1 校验和,该值唯一标识了加载的 lua 脚本。

图片

这会返回sha1 校验和: a1104f2250e5dd9fc10c3c681ddb389e7bd4a2cf

2、执行 lua 脚本:

一旦 lua 脚本被加载并获得了 sha1 校验和,之后就可以使用 evalsha 命令来执行该脚本。

图片

5.3 springboot例子

图片

首先分别设置三个键(key:a, b, c)的值,然后分别设置键为 "myhashkey" 下的三个字段(field)的值, 并编写 lua 脚本,执行 lua 脚本并获取结果。

6 总结

本文介绍了redis 中批量查询的四种技巧:

1、mget(批量获取字符串值):

简单直接,适用于批量获取字符串值的场景。

2、hmget(批量获取哈希表字段值):

适用于批量获取哈希表中的字段值,可以在一个命令中获取多个字段。

3、pipeline(管道):

最小化网络开销,一次性发送多个不同的命令,管道中的命令按照执行顺序依次执行,减少往返时间。高并发场景下,可以显著提高性能。

4、lua脚本:

使用 lua 脚本的好处 :

当然 使用 lua 脚本也会有瑕疵,编写和维护相对复杂。

以上就是redis批量查询的四种方式详解的详细内容,更多关于redis批量查询方式的资料请关注代码网其它相关文章!

(0)

您想发表意见!!点此发布评论

推荐阅读

Redis事务处理的实现示例

10-19

redis中红锁的使用小结

10-20

Redis的复制延迟优化的实现步骤

10-20

Redis中Redlock算法的具体使用

10-20

Redis分布式锁的超时机制实现的方法示例

10-20

Redis中Lua脚本的常见场景

10-20

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论