redis与lua整合

redis与lua整合

redis原生支持watch监听、multi事务、exec批处理。但是下面的代码无法获取上面代码的执行结果。上下文关系不存在。lua可以帮助完善redis功能。

redis 原生支持 监听、事务、批处理,那么还需要lua吗?

  • 两者不存在竞争关系,而是增强关系,lua可以完成redis自身没有的功能

  • 在lua中可以使用上一步的结果,也就是可以开发后面操作依赖前面操作的执行结果的应用,MULT中的命令都是独立操作

  • redis可以编写模块增强功能,但是c语言写模块,太难了,lua简单的多

  • 计算向数据移动

  • 原子操作

lua脚本尽量短小并且尽量保证同一事物写在一段脚本内,因为redis是单线程的,过长的执行会造成阻塞,影响服务器性能

redis与lua整合 

redis与lua整合

0表示不带参数,也可以传参数:

redis与lua整合

redis与lua整合

vi test.lua:

redis与lua整合

redis-cli --eval test.lua:注意这种写法支支持Lua5.1以上版本

redis与lua整合

在lua脚本中可以通过redis.call调redis原生的命令来获取值等操作:

vi test2.lua:

redis与lua整合

redis与lua整合

redis与lua整合

redis与lua整合

魔兽世界的客户端几乎都使用lua写的。