Redis中lua脚本和pipeline的区别

一、lua脚本

一般我会用lua脚本来代替。

官方默认lua脚本是原子性的,应该是和MySQL的原子行差不多的。

lua脚本的所有命令要么全部执行成功要么全部执行失败。

一般是做一些逻辑比较严密的处理。

阻塞其他redis操作,直到lua脚本完全执行完毕才会执行其他命令。

我认为lua可以执行批量处理

如果lua脚本执行的时间太长,那么要优化下lua脚本,因为lua会阻塞其他操作,所以说lua脚本不适合执行太长时间。

三、pipeline

1、批量处理数据,一次性返回所有结果集。就可以对这个结果集进行处理,考验处理结果集的能力。

一个pipeline的命令集被redis服务器执行的时候,有可能redis服务器会执行其他客户端传来的redis命令。

一些异常情况尽可能发生,所以说使用pipeline一般会做一些异常捕获和处理。

pipeline是顺序执行的吗
  • pipeline缓冲的指令发送到服务器端时,本身是按照指令缓冲的顺序执行,因为缓冲指令是使用队列的方式实现的,但是缓冲指令中间可能会穿插其他客户端发送来的命令

Pipeline 的优点:

批量操作:Pipeline 适用于需要批量执行多个命令的场景,通过一次性发送多个命令,减少了客户端与服务器之间的通信次数。

提升吞吐量:Pipeline 可以在一次请求中发送多个命令,减少了网络延迟时间,提高了性能。

简单易用:使用 Java 客户端的 Pipeline API 相对简单,易于理解和维护。

Pipeline 的缺点:

无回滚机制:Pipeline 无法保证所有命令都执行成功,需要手动检查每个命令的执行结果。

Lua 脚本的优点:

复杂计算处理:Lua 脚本可以编写复杂的逻辑,结合 Redis 的数据结构和操作,实现更灵活和强大的功能。

原子性操作:Lua 脚本执行是原子性的,可以保证多个命令在一个单独的 Lua 脚本中依次执行,确保操作的原子性。

Lua 脚本的缺点:

学习和编写成本:Lua 脚本相对于 Java 代码来说,需要学习新的语法和规则,在编写和调试方面有一定的门槛。

可读性和可维护性:Lua 脚本相对于 Java 代码来说,可读性和可维护性较低,不容易理解和修改。

根据场景的不同,可以根据以下几个维度进行选择:

批量操作和提升吞吐量:如果需要批量执行多个命令和提升系统的吞吐量,建议使用 Pipeline。

复杂计算和业务逻辑:如果需要进行复杂的计算和处理,建议使用 Lua 脚本。

通常情况下,Pipeline 和 Lua 脚本可以结合使用,根据具体要求和场景选择适合的方法。

原文链接:

https://blog.csdn.net/ws_please/article/details/131623599

https://blog.51cto.com/u_16213689/7240017

相关推荐
Java开发的小李1 小时前
SpringBoot + Redis 实现分布式 Session 共享(解决多实例登录状态丢失问题)
spring boot·redis·分布式
daixin88484 小时前
cursor无法正常使用gpt5.5等模型解决方案
java·redis·cursor
小猿姐5 小时前
Redis Kubernetes Operator 实测:三个方案的真实差距
redis·容器·kubernetes
aLTttY10 小时前
Spring Boot + Redis 实现接口防抖与限流实战指南
spring boot·redis·junit
Lyyaoo.11 小时前
TreadLocal和TreadLocalMap
android·java·redis
为美好的生活献上中指12 小时前
本地虚拟机部署redis集群
前端·redis·ubuntu·bootstrap·html·redis集群
coderlin_12 小时前
Langgraph项目三 agent搭建
java·数据库·redis
XiYang-DING14 小时前
【Java EE】锁策略、锁升级、锁消除和锁粗化
java·redis·java-ee
Devin~Y15 小时前
大厂Java面试实录:Spring Boot/Cloud + Redis/Kafka + JWT + RAG/Agent(小Y翻车版)
java·spring boot·redis·spring cloud·kafka·spring security·jwt
xingpanvip15 小时前
星盘接口开发文档:天象盘接口指南
android·开发语言·python·php·lua