内容简介:最近在配合移动端调试的时候,被抓去debug一个在清除redis缓存之后才会出现的网关错误。于是打开服务器上的log定位到类似错误:该段代码的主要作用是在通过查询资料得知原因:
最近在配合移动端调试的时候,被抓去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
以上所述就是小编给大家介绍的《lua读取redis数据的null判断》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 你有没有想过: Java 虚拟机是如何判断两个对象是否相同的?判断的流程是什么?
- iOS Rotation 判断
- 判断是否是闰年
- 数值类型(金额)限制与判断
- ansible笔记(26):条件判断
- 判断Golang接口是否实现
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
民事诉讼程序研究
乔罗威茨 / 吴泽勇 / 2008-6 / 40.00元
《民事诉讼程序研究》共分为诉讼程式;扩散利益、分散利益和集体利益的保护;程式样式;当事人与法官;对判決的救济;程式改革。主要內容包括:民事诉讼;英美民事诉讼程式在20世纪的若干发展;论民事诉讼法的本质和目的等。一起来看看 《民事诉讼程序研究》 这本书的介绍吧!