Redis分布式缓存系统Lua脚本食用指引
时间:2022-04-29
本文章向大家介绍Redis分布式缓存系统Lua脚本食用指引,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Redis 为什么添加 Lua 支持
redis lua 脚本出现之前 Redis 是没有服务器端运算能力的,主要是用来存储,用做缓存,运算是在客户端进行,这里有两个缺点:一、如此会破坏数据的一致性,试想如果两个客户端先后获取(get)一个值,它们分别对键值做不同的修改,然后先后提交结果,最终 Redis 服务器中的结果肯定不是某一方客户端所预期的。二、浪费了数据传输的网络带宽。
lua 出现之后这一问题得到了充分的解决,非常棒!有了 Lua 的支持,客户端可以定义对键值的运算。总之,可以让 Redis 更为灵活。
Redis 支持Lua的版本
>=2.6
Redis Lua脚本食用注意事项
1、不支持多keys跨集群操作
2、Lua脚本原理
http://redisbook.readthedocs.io/en/latest/feature/scripting.html
Redis Lua Java实战
1、首先,JedisCluster方式食用改造:
public Object eval(final String slot_key, final String script, final List<String> keys, final List<String> params) {
return new JedisClusterCommand<Object>(connectionHandler, maxRedirections) {
@Override
public Object execute(Jedis connection) {
return connection.eval(script, keys, params);
}
}.run(slot_key);
}
2、库存判定的实战:
String slot_key = "test";
//先get后decr
String srcipt = "local curRemNum = tonumber(redis.call('get', KEYS[1]))n if curRemNum <= 0 then n return -1 n end n redis.call('decr', KEYS[1]) n return 1";
//先decr后补偿set
//String srcipt = "local curRemNum = tonumber(redis.call('decr', KEYS[1]))n if curRemNum < 0 then n redis.call('set', KEYS[1],'0') n return -1 n end n return 1";
ArrayList keys=new ArrayList();
keys.add(slot_key);
JedisCluster jc = (JedisCluster) zcacheCli.getOrigin();
jc.eval(slot_key, script, keys, new ArrayList());
--author by caizhengluan e-mail: SvenAugustus@outlook.com 如有转载,请标明转载,并附上原始链接,谢谢。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Linux删除目录下的文件的10种方法小结
- 利用Linux防火墙隔离本地欺骗地址的方法详解
- 视图在SQL中的作用是什么,它是怎样工作的?
- Linux命令行上如何使用日历详解
- 在Linux下修改和重置root密码的方法(超简单)
- 在Centos上搭建Maven中央仓库的方法
- 详解Ubuntu16.04启动器图标异常解决方法
- Linux(ubuntu)下实现增加/删除文件权限
- Vim中文件编码处理与重新打开乱码文件详解
- Linux常用命令mkdir详解
- CentOS6.5环境下使用rsync增量同步备份文件的方法
- Linux 搭建Git服务器的方法
- Linux中无法远程连接数据库问题的解决方法
- VIM实现文件快速跳转插件详解
- 详解linux usb host驱动编写入门