时间:2021-05-22
前言
为什么要用lua脚本操作redis数据库?
1.减少开销–减少向redis服务器的请求次数
2.原子操作–redis将lua脚本作为一个原子执行
3.可复用–其他客户端可以使用已经执行过的lua脚本
4.增加redis灵活性–lua脚本可以帮助redis做更多的事情
lua脚本本身体积小,启动速度快.
因此,从redis 2.6.0开始,redis在服务器端内置lua解释器,下面话不多说了,来开始本文的正文:
最近在配合移动端调试的时候,被抓去debug一个在清除redis缓存之后才会出现的网关错误。于是打开服务器上的log定位到类似错误:
[error] 7#7: *12030 lua entry thread aborted: runtime error: /data/share/apps/lua/access_check.lua:133: bad argument #1 to 'decode' (string expected, got userdata)
该段代码的主要作用是在openresty中lua读取redis中数据并解码为json:
local access_token = redis_client:read_by_key(token_key) if access_token == nil then -- do something... return false end local obj_token = cjson.decode(access_token) -- do something通过查询资料得知原因:lua读取redis数据返回结果为空时,返回的结果不是nil而是userdata类型的ngx.null。
为什么要这么设计?
因为nil在lua中有特殊的意义,如果一个变量被设置为nil相当于告知该变量未定义(不存在)一样,如果把redis查询的结果为空设置为nil,而该查询的key对应在redis中又是存在的,就无法把查询为空和未定义区分开来了,这样显然是不合理的。所以必须使用一个userdata类型的值来表示这个查询记录为空,但是又不等同于未定义变量(ngx.null)。
因此,代码做如下修改即可:
local access_token = redis_client:read_by_key(token_key) if access_token == ngx.null or access_token == nil then -- do something... return false end local obj_token = cjson.decode(access_token) -- do something总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文介绍如何用Nginx+Lua+Redis来构建高并发Web应用,Curl请求Nginx,Nginx通过Lua查询Redis,返回json数据。一、安装1、安
下面代码是读取的节点数据,还有一种情况是读取节点属性数据。varobjLength=null;varxmlHttp;varstrurl="";functiona
lua脚本Redis中使用lua脚本,我们需要注意的是,从Redis2.6.0后才支持lua脚本的执行。使用lua脚本的好处:原子操作:lua脚本是作为一个整体
判断方法结论:复制代码代码如下:a={}ifnext(a)~=nilthendosomethingend最近在项目里面大量使用的lua,其中lua的table是
Lua中I/O库用于读取和处理文件。有两种类型的文件操作,在Lua即隐含文件的描述符和明确的文件描述符。对于下面的例子中,我们将使用一个示例文件test.lua