深入浅出Redis(十):Redis的Lua脚本

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 深入浅出Redis(十):Redis的Lua脚本

引言

Redis是一款基于内存的键值对数据库,提供了多种数据结构存储数据,存取数据的速度还非常快,除了这些优点它还提供了其他特色功能,比如:管道、lua脚本、发布订阅模型

使用lua脚本能够让Redis服务器原子性的执行一系列操作,Redis实现分布式锁时保证复合操作的原子性就可以通过lua脚本来进行实现

本篇文章主要描述lua脚本,将围绕lua脚本深入浅出的描述如何使用lua脚本,lua脚本执行实现原理以及主从情况下脚本复制问题

使用Lua脚本相关命令

eval "脚本内容" 参数个数 keys键 argv参数 执行lua脚本,keys数组表示key占位,argv数组表示参数占位

evalsha 根据校验和执行lua脚本(校验和是生成脚本时而生成的唯一标识,用于标识对应脚本

script load 根据lua脚本生成校验和

script exists 根据校验和判断脚本是否存在

script flush 清空脚本

script kill 执行脚本超时时杀死

#脚本内容 返回 redis call函数执行结果  call函数:set testkey testvalue
 127.0.0.1:6379> eval "return redis.call('set',KEYS[1],ARGV[1])" 1 testkey testvalue
 OK
 
 #get testkey
 127.0.0.1:6379> eval "return redis.call('get','testkey')" 0
 "testvalue"
 
 #将脚本加入字典,生成校验和
 127.0.0.1:6379> script load "return redis.call('get','testkey')"
 "e3806601db83b4206d0e875f774193ee4f77333f"
 
 #判断校验和对应脚本是否存在
 127.0.0.1:6379> script exists "e3806601db83b4206d0e875f774193ee4f77333f"
 1) (integer) 1
 127.0.0.1:6379>  script exists "ttttttttttttttttt"
 1) (integer) 0
 
 #通过校验和执行脚本
 127.0.0.1:6379> evalsha  "e3806601db83b4206d0e875f774193ee4f77333f" 0
 "testvalue"

Lua脚本原理

原始的lua环境不满足redis的使用,redis会导入一些函数库强化lua环境,最终使用修改后的lua环境

使用两个组件实现lua脚本功能,一个组件是执行lua脚本的伪客户端,另一个是脚本字典,用于维护K校验和与V脚本,通过脚本字典能够实现很多命令功能

命令及实现原理

  • eval
  1. 根据脚本生成函数,函数名为校验和定义
  2. 维护脚本字典,加入K(校验和)V(脚本)
  3. 执行函数(前需要导入keys数组、argv数组参数,执行完函数将响应数据放入输出缓冲区,定时钩子函数检查执行脚本是否超时,script kill 来结束超时脚本)
  • evalsha:根据校验和找到对应函数来执行
  • script exists:根据校验和查询脚本字典判断脚本是否存在
  • script load:与eval类似,根据脚本生成函数并维护脚本字典,但不执行,返回校验和
  • script flush:重置脚本字典和lua环境

脚本复制

当主从集群情况下,如果主节点以及维护了脚本但从节点还没维护脚本,客户端请求evalsha命令,主节点会执行成功,但还未维护脚本的从节点会执行失败

如果从节点都维护了脚本那么可以运行evalsha,如果从节点没维护脚本,那么主节点复制时需要将evalsha命令转换为eval命令告诉从节点维护脚本(根据校验和查到脚本字典的脚本再转换为eval命令)

为了避免这种情况发生,使用脚本缓冲字典来判断主从复制时,从节点是否都维护了该脚本,K为脚本校验和,V为空,可以看成Set

当主节点执行evalsha时,查看脚本缓冲字典判断从节点是否都维护了该脚本,如果维护了直接发送,否则根据校验和查询脚本字典获取脚本,将evalsha命令转换为eval命令再发送给从节点

总结

本篇文章围绕lua脚本深入浅出的解析如何使用lua脚本、lua脚本实现原理以及脚本复制问题

原始的lua环境不满足Redis的使用,Redis导入其他函数库强化lua环境

使用伪客户端帮助lua脚本发送命令给服务端,在服务端维护脚本字典以此来实现lua脚本相关命令,lua脚本最终会生成函数执行,参数等信息来源于lua脚本的命令

主从架构下,为了防止使用evalsha命令主从执行不一致,会使用脚本缓存字典来判断主从中是否都维护了对应的脚本

最后

  • 参考资料
  • 《Redis深度历险》
  • 《Redis设计与实现》


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
5天前
|
弹性计算 NoSQL Shell
redis没设置密码,莫名被设置了4个sh脚本
阿里云ECS实例上未设密码的Redis服务被发现含有未知来源的SH脚本,这些脚本定时从外部URL下载并执行代码。这可能是服务器遭受恶意攻击的迹象。建议立即检查系统日志,确认是否被黑,并移除这些脚本。同时,为Redis设置密码,加强安全防护。若不确定,可寻求专业安全团队帮助。
32 2
|
5天前
|
存储 NoSQL 调度
Redis Lua脚本:原子性的真相揭秘
【4月更文挑战第20天】
67 0
Redis Lua脚本:原子性的真相揭秘
|
5天前
|
缓存 NoSQL Java
lua脚本在redis中的使用场景
lua脚本在redis中的使用场景
|
5天前
|
NoSQL Java Redis
lua脚本做redis的锁
这段内容是关于使用Redis实现分布式锁的Java代码示例。`RedisLock`类包含`lock`和`unlock`方法,使用`StringRedisTemplate`和Lua脚本进行操作。代码展示了两种加锁方式:一种带有过期时间,另一种不带。还提到了在加锁和解锁过程中的异常处理,并提供了相关参考资料链接。
20 3
|
缓存 NoSQL Redis
Redis命令——脚本
Redis 脚本使用 Lua 解释器来执行脚本。 Reids 2.6 版本通过内嵌支持 Lua 环境。执行脚本的常用命令为 EVAL。
1359 0
|
缓存 NoSQL Redis
redis必杀命令:脚本
题记: Redis 脚本使用 Lua 解释器来执行脚本。 Reids 2.6 版本通过内嵌支持 Lua 环境。执行脚本的常用命令为 EVAL。
1261 0
|
5天前
|
负载均衡 监控 NoSQL
Redis的几种主要集群方案
【5月更文挑战第15天】Redis集群方案包括主从复制(基础,读写分离,手动故障恢复)、哨兵模式(自动高可用,自动故障转移)和Redis Cluster(官方分布式解决方案,自动分片、容错和扩展)。此外,还有Codis、Redisson和Twemproxy等工具用于代理分片和负载均衡。选择方案需考虑应用场景、数据量和并发需求,权衡可用性、性能和扩展性。
38 2
|
5天前
|
存储 监控 负载均衡
保证Redis的高可用性是一个涉及多个层面的任务,主要包括数据持久化、复制与故障转移、集群化部署等方面
【5月更文挑战第15天】保证Redis高可用性涉及数据持久化、复制与故障转移、集群化及优化策略。RDB和AOF是数据持久化方法,哨兵模式确保故障自动恢复。Redis Cluster实现分布式部署,提高负载均衡和容错性。其他措施包括身份认证、多线程、数据压缩和监控报警,以增强安全性和稳定性。通过综合配置与监控,可确保Redis服务的高效、可靠运行。
27 2
|
5天前
|
存储 NoSQL Redis
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群(下)
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群
20 1
|
5天前
|
监控 NoSQL Redis
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群(上)
Redis源码、面试指南(5)多机数据库、复制、哨兵、集群
34 0