最近使用了一个lua 自动熔断类,测试的时候发现openresty有一个错误提醒:
[error] 13522#13522: *10466335 failed to run log_by_lua*: /htdocs/utils/url_fuse.lua:121: expecting 3 or 4 arguments, but only seen 5
stack traceback:
[C]: in function 'incr'
/htdocs/utils/url_fuse.lua:121: in function 'count'
/htdocs/utils/url_fuse.lua:111: in function 'run_log'
翻了一下没有找到相关的解决方案,有网友说是openresty版本的问题,仔细查阅了官方git的说明,发现了这个:
ngx.shared.DICT.incr
Note: Usage of the init_ttl argument requires the resty.core.shdict or resty.core modules from the lua-resty-core library.
Example:
require "resty.core"
local cats = ngx.shared.cats
local newval, err = cats:incr("black_cats", 1, 0, 0.1)
print(newval) -- 1
ngx.sleep(0.2)
local val, err = cats:get("black_cats")
print(val) -- nil
加上 require “resty.core” 之后问题解决