redis与lua整合
redis原生支持watch监听、multi事务、exec批处理。但是下面的代码无法获取上面代码的执行结果。上下文关系不存在。lua可以帮助完善redis功能。
redis 原生支持 监听、事务、批处理,那么还需要lua吗?
两者不存在竞争关系,而是增强关系,lua可以完成redis自身没有的功能
在lua中可以使用上一步的结果,也就是可以开发后面操作依赖前面操作的执行结果的应用,MULT中的命令都是独立操作
redis可以编写模块增强功能,但是c语言写模块,太难了,lua简单的多
计算向数据移动
原子操作
lua脚本尽量短小并且尽量保证同一事物写在一段脚本内,因为redis是单线程的,过长的执行会造成阻塞,影响服务器性能
0表示不带参数,也可以传参数:
vi test.lua:
redis-cli --eval test.lua:注意这种写法支支持Lua5.1以上版本
在lua脚本中可以通过redis.call调redis原生的命令来获取值等操作:
vi test2.lua:
魔兽世界的客户端几乎都使用lua写的。