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

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏晨星先生的自留地

django(2)setting配置文件详解

1703
来自专栏大内老A

我的WCF之旅(1):创建一个简单的WCF程序

为了使读者对基于WCF的编程模型有一个直观的映像,我将带领读者一步一步地创建一个完整的WCF应用。本应用功能虽然简单,但它涵盖了一个完整WCF应用的基本结构。对...

2118
来自专栏.NET后端开发

如何通过经纬度获取地址信息?

摘要 Google Maps API Web Services,是一个为您的地图应用程序提供地理数据的 Google 服务的 HTTP 接口集合。具体包括:Go...

56911
来自专栏小二的折腾日记

《redis 设计与实现》--总结

Redis自己构建了简单动态字符串(Simple Dynamic String,SDS)来作为默认的字符串表示。 SDS的构造如下:

2484
来自专栏大内老A

ASP.NET Core真实管道详解[2]:Server是如何完成针对请求的监听、接收与响应的【上】

Server是ASP .NET Core管道的第一个节点,负责完整请求的监听和接收,最终对请求的响应同样也由它完成。Server是我们对所有实现了IServer...

3475
来自专栏python3

习题11:提问

How old are you? 18 How tall are you? 180 How much do you weight? 130 So,you're ...

803
来自专栏大内老A

WCF技术剖析之二十三:服务实例(Service Instance)生命周期如何控制[下篇]

在[第2篇]中,我们深入剖析了单调(PerCall)模式下WCF对服务实例生命周期的控制,现在我们来讨轮另一种极端的服务实例上下文模式:单例(Single)模式...

2129
来自专栏大内老A

WCF技术剖析之三十一: WCF事务编程[中篇]

[续《上篇》]通过将TransactionFlowAttribute特性应用在服务契约的某个操作之上,并指定相应的TransactionFlowOption枚举...

2225
来自专栏智能合约

PHP性能分析之Xhprof数据说明

1386
来自专栏小二的折腾日记

《redis 设计与实现》--总结

Redis自己构建了简单动态字符串(Simple Dynamic String,SDS)来作为默认的字符串表示。 SDS的构造如下:

922

扫码关注云+社区

领取腾讯云代金券