当前位置:   article > 正文

Redis(五):Lua脚本_lua 退出整个脚本

lua 退出整个脚本

Redis2.6版本开始支持Lua脚本,通过在服务器端嵌入Lua环境,客户端可以使用Lua脚本在服务器端原子的执行多个命令。
Redis服务器会单线程原子性执行Lua脚本,保证Lua脚本在处理的过程中不会被任意其它请求打断。

创建并修改Lua环境

为了在Redis服务器中执行Lua脚本,需要在Redis服务器内嵌一个Lua环境。因为Redis在任何时间最多只有一个脚本被放进Lua环境中执行,所以一个Redis服务器只需要创建一个Lua环境。

  1. 调用lua_open函数创建一个基本的Lua环境;—— 接下来的步骤都是针对这个Lua环境操作
  2. 载入多个函数库到Lua环境;—— Lua脚本基于这些函数库进行数据操作
  3. 在LuaLua中创建一个redis表格全局变量table;—— 包含对Redis进行操作的函数
  4. 使用Redis自制的随机函数替换Lua原有的随机函数;
  5. 创建排序函数;—— 对Redis命令的结果进行排序,消除不确定性
  • 什么是不确定性?—— 集合是无序的,即使两个集合包含的元素完全相同,输出的结果也可能不同。
  • 不确定性的命令:sintersunionsdiff、smembershkeyshvalskeys
  • 如何消除不确定性:当Lua脚本执行完一个带有不确定的命令后,会调用table.sort函数对命令的
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/859090
推荐阅读
相关标签
  

闽ICP备14008679号