Redis批量操作的实现示例

 更新时间:2025年11月26日 09:12:37   作者:wujiada001  
本文主要介绍了Redis批量操作的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、原生批量命令(MSET)

适用场景:所有键的过期时间相同或无过期设置,且无需条件判断。 方法: 将多个SET命令合并为MSET命令,但需要注意MSET的局限性(无法设置过期时间,且所有键值对必须一次性设置)。

MSET CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201183046858 1 CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201182841857 1 ...(其他键值对)

优点:网络开销最小,一次请求完成所有操作。

缺点:无法设置过期时间,且要求所有键在同一哈希槽(集群模式下需使用哈希标签{})。

二、Pipeline(管道)

适用场景:需高效批量执行命令且允许非原子性操作。

1. 命令行操作

将命令写入文件后通过管道执行:

# 创建命令文件 commands.txt
echo "SET CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201183046858 1" >> commands.txt
# 追加其他命令...

# 通过redis-cli执行
cat commands.txt | redis-cli -h <host> -p <port> -a <password> --pipe

优点:减少网络往返次数,适合大规模批量操作。

2. 编程语言实现(以Python为例)

import redis

r = redis.Redis(host='localhost', port=6379)
pipe = r.pipeline()

keys = [
    "CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201183046858",
    "CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201182841857",
    # ...其他键
]

for key in keys:
    pipe.set(key, 1)

pipe.execute()

优点:代码灵活,支持扩展(如设置过期时间)

三、Lua脚本

适用场景:需原子性执行所有命令。

local keys = {
    'CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201183046858',
    'CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201182841857',
    -- 其他键
}

for _, key in ipairs(keys) do
    redis.call('SET', key, 1)
end

执行命令

redis-cli -h <host> -p <port> -a <password> EVAL "$(cat script.lua)" 0

优点:保证原子性,适合对一致性要求高的场景。

四、Redis事务(MULTI/EXEC)

适用场景:需保证命令按顺序执行,但非严格原子性(集群模式下需所有键在同一哈希槽)。

MULTI
SET CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201183046858 1
SET CUSTOMER_STAR:STAFF_20220311161756037_CUS_20240201182841857 1
...
EXEC

优点:命令顺序执行,支持条件判断(如WATCH)

缺点:集群模式下需使用哈希标签确保键在同一节点

五、Redis集群模式优化

问题:若为集群环境,需确保所有键在同一哈希槽。 解决方案

  1. 使用哈希标签:在键名中使用{}包裹相同部分,例如:
    SET CUSTOMER_STAR:{STAFF_20220311161756037}_CUS_20240201183046858 1

    所有键的哈希标签{STAFF_20220311161756037}将分配到同一槽

  2. 分节点执行:若无法使用哈希标签,需将命令按哈希槽分组后分别发送到对应节点。

六、性能优化建议

  1. 控制批量大小:单次Pipeline建议不超过500条命令,避免内存或网络阻塞 。
  2. 错误处理:Pipeline和Lua脚本需捕获并处理部分失败的情况 。
  3. 网络优化:优先使用内网连接,减少延迟 。

七、执行方式对比

方法原子性网络开销适用场景集群兼容性
MSET最低简单键值批量设置需哈希标签
Pipeline高效非原子批量操作需哈希标签或分片
Lua脚本复杂逻辑或原子性要求高需哈希标签
事务顺序执行且需条件判断需哈希标签

选择建议:若无原子性要求,优先使用Pipeline;若需原子性且逻辑简单,使用Lua脚本

到此这篇关于Redis批量操作的实现示例的文章就介绍到这了,更多相关Redis批量操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Redis 命令的详解及简单实例

    Redis 命令的详解及简单实例

    这篇文章主要介绍了Redis 命令的详解及简单实例的相关资料,这里提供基础语法及使用实例,需要的朋友可以参考下
    2017-08-08
  • Redis分布式锁一定要避开的两个坑

    Redis分布式锁一定要避开的两个坑

    这篇文章主要为大家详细介绍了Redis中分布式锁一定要避开的两个坑以及对应的解决方法,文中的示例代码讲解详细,希望对大家有所帮助
    2023-04-04
  • 配置redis的序列化,注入RedisTemplate方式

    配置redis的序列化,注入RedisTemplate方式

    这篇文章主要介绍了配置redis的序列化,注入RedisTemplate方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Redis模仿发送手机验证码功能

    Redis模仿发送手机验证码功能

    这篇文章主要介绍了Redis模仿手机验证码发送功能,通过示例代码给大家讲解通过用户输入手机号以及验证码进行校验,代码简单易懂,需要的朋友可以参考下
    2021-09-09
  • Redis实现分布式锁的几种方法总结

    Redis实现分布式锁的几种方法总结

    这篇文章主要介绍了Redis实现分布式锁的几种方法总结的相关资料, Redis实现与Zookeeper实现和数据库实现,需要的朋友可以参考下
    2017-07-07
  • Redis字符串原理的深入理解

    Redis字符串原理的深入理解

    这篇文章主要给大家介绍了关于Redis字符串原理的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • redis key键过期删除策略及淘汰机制探究

    redis key键过期删除策略及淘汰机制探究

    这篇文章主要为大家介绍了redis key键过期删除策略及淘汰机制探究,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • Redis 命令详解与实战案例

    Redis 命令详解与实战案例

    本文详细介绍了Redis的基础知识、核心数据结构与命令、高级功能与命令、最佳实践与性能优化,以及实战应用场景,通过实战案例,展示了如何使用Redis构建高性能应用系统,感兴趣的朋友跟随小编一起看看吧
    2025-11-11
  • redis在php中常用的语法【推荐】

    redis在php中常用的语法【推荐】

    string是redis最基本的类型,而且string类型是二进制安全的。这篇文章主要介绍了redis在php中常用的语法,需要的朋友可以参考下
    2018-08-08
  • redis批量删除key的步骤

    redis批量删除key的步骤

    本文分享最新版Redis批量删除key的方法,希望能帮到遇到同样问题的网友。
    2020-09-09

最新评论