文档章节

Redis分布式缓存系统Lua脚本食用指引

斯武丶风晴
 斯武丶风晴
发布于 2016/06/15 15:45
字数 428
阅读 184
收藏 2

Redis 为什么添加 Lua 支持

redis lua 脚本出现之前 Redis 是没有服务器端运算能力的,主要是用来存储,用做缓存,运算是在客户端进行,这里有两个缺点:一、如此会破坏数据的一致性,试想如果两个客户端先后获取(get)一个值,它们分别对键值做不同的修改,然后先后提交结果,最终 Redis 服务器中的结果肯定不是某一方客户端所预期的。二、浪费了数据传输的网络带宽。

lua 出现之后这一问题得到了充分的解决,非常棒!有了 Lua 的支持,客户端可以定义对键值的运算。总之,可以让 Redis 更为灵活。

Redis 支持Lua的版本

>=2.6

Redis Lua脚本食用注意事项

1、不支持多keys跨集群操作

http://stackoverflow.com/questions/24124847/can-a-lua-script-that-is-run-on-one-node-get-keys-from-another-node-in-redis-c

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 如有转载,请标明转载,并附上原始链接,谢谢。

 

© 著作权归作者所有

斯武丶风晴
粉丝 57
博文 49
码字总数 61098
作品 0
广州
高级程序员
私信 提问
《Redis实战》下载

首部分对Redis进行了介绍,说明了Redis的基本使用方法、它拥有的5种数据结构以及操作这5种数据结构的命令,并讲解了如何使用Redis去构建文章展示网站、cookie、购物车、网页缓存、数据库行缓...

ddddd8
2017/12/13
0
0
Redis进阶实践之十九 Redis如何使用lua脚本

Redis进阶实践之十九 Redis如何使用lua脚本 一、引言 redis学了一段时间了,基本的东西都没问题了。从今天开始讲写一些redis和lua脚本的相关的东西,lua这个脚本是一个好东西,可以运行在任何...

morpheusWB
2018/09/13
77
0
OpenResty(nginx+lua) 开发入门

OpenResty 官网:http://openresty.org/ OpenResty® - 中文官方站 http://openresty.org/cn/ OpenResty 是一个nginx和它的各种三方模块的一个打包而成的软件平台。最重要的一点是它将lua/l...

English0523
2017/11/13
0
0
lua与redis结合

一,Redis和Lua结合 1:redis.call:在脚本中调用Redis命令,遇到错误会直接返回 2:redis.pcall:在脚本中调用Redis命令,遇到错误会记录错误并继续执行 3:Lua数据类型和Redis返回值类型对...

daydayup08
2016/04/27
51
0
亿级流量电商详情页系统的大型高并发与高可用缓存架构实战

对于高并发的场景来说,比如电商类,o2o,门户,等等互联网类的项目,缓存技术是Java项目中最常见的一种应用技术。然而,行业里很多朋友对缓存技术的了解与掌握,仅仅停留在掌握redis/memca...

登录404
2017/06/05
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

java通过ServerSocket与Socket实现通信

首先说一下ServerSocket与Socket. 1.ServerSocket ServerSocket是用来监听客户端Socket连接的类,如果没有连接会一直处于等待状态. ServetSocket有三个构造方法: (1) ServerSocket(int port);...

Blueeeeeee
今天
6
0
用 Sphinx 搭建博客时,如何自定义插件?

之前有不少同学看过我的个人博客(http://python-online.cn),也根据我写的教程完成了自己个人站点的搭建。 点此:使用 Python 30分钟 教你快速搭建一个博客 为防有的同学不清楚 Sphinx ,这...

王炳明
昨天
5
0
黑客之道-40本书籍助你快速入门黑客技术免费下载

场景 黑客是一个中文词语,皆源自英文hacker,随着灰鸽子的出现,灰鸽子成为了很多假借黑客名义控制他人电脑的黑客技术,于是出现了“骇客”与"黑客"分家。2012年电影频道节目中心出品的电影...

badaoliumang
昨天
16
0
很遗憾,没有一篇文章能讲清楚线程的生命周期!

(手机横屏看源码更方便) 注:java源码分析部分如无特殊说明均基于 java8 版本。 简介 大家都知道线程是有生命周期,但是彤哥可以认真负责地告诉你网上几乎没有一篇文章讲得是完全正确的。 ...

彤哥读源码
昨天
18
0
jquery--DOM操作基础

本文转载于:专业的前端网站➭jquery--DOM操作基础 元素的访问 元素属性操作 获取:attr(name);$("#my").attr("src"); 设置:attr(name,value);$("#myImg").attr("src","images/1.jpg"); ......

前端老手
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部