前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis分布式缓存系统Lua脚本食用指引

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

作者头像
斯武丶风晴
发布2018-03-01 10:58:45
1.3K0
发布2018-03-01 10:58:45
举报
文章被收录于专栏:龙首琴剑庐龙首琴剑庐

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方式食用改造:

代码语言:javascript
复制
	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、库存判定的实战:

代码语言:javascript
复制
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 如有转载,请标明转载,并附上原始链接,谢谢。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档