lua_shared_dict设置一块共享内存区域,可以被各个worker共享
写在http模块中
比如下面这个,表示设置了一块共享的内存区域,大小为10m.
lua_shared_dict sdata 10m;
设置了这里面就可以存数据了,怎么读写数据呢?有set和get方法,直接可以往这块共享内存写数据
测试一下
测试代码写在外部lua文件中,这里引入一下
server {
listen 80;
server_name localhost;
location / {
stub_status on;
default_type text/html;
content_by_lua_file /usr/local/openresty/lualib/luatest/tmp.lua;
}
}
外部lua代码如下
-- 获取共享内存的dict对象
local x=ngx.shared.sdata
-- 在共享内存里放个kv对
x:set("a","apple")
ngx.say("STOREDS")
-- 获取数据
ngx.say(x:get("a"))
打开网页刷新测试一下,可以看出已经获取到了存储在共享内存的值.
总结
- ngx.shared 加上共享内存的名字可以获取这个共享的dict对象
- 可以用set方法往共享内存中存数据,同时可以利用get方法从共享内存中取值