LUA实例:查询优化技术之多级缓存

查询优化技术之多级缓存

nginx的代理缓存配置方式

nginx proxy cache缓存的配置方式:在nginx.conf中申明如下内容

# 申明一个cache缓存节点的路径
proxy_cache_path /usr/local/openresty/nginx/cache_temp levels=1:2 keys_zone=tmp_cache:100m inactive=7d max_size=100g;

# /usr/local/openresty/nginx/cache_temp 缓存文件位置
# levels 目录设置了两级结构用来缓存
# keys_zone 指定一个叫tmp_cache的缓存区,并且设置100m的内存用来存储缓存key到文件路径的位置
# inactive 缓存文件超过7天后自动释放淘汰
# max_size 缓存文件总大小超过100g后自动释放淘汰

location内加入

proxy_cache tmp_cache;
proxy_cache_valid 200 206 304 302 10d;
proxy_cache_key $request_uri;

openresty扩展

加载lua模块

http模块如下

lua_package_path "/usr/local/openresty/?.lua;;"; # lua模块
lua_package_cpath "/usr/local/openresty/lualib/?.so;;" # c模块

测试lua输出

location = /lua {
    default_type 'text/plain';
    content_by_lua 'ngx.say("hello, lua!")';
}

shared dict扩展

  • 修改nginx.conf内,加入shared diction的扩展,申明128m的共享字典的访问内存
lua_shared_dict my_cache 128m;
  • 设置location用来做访问shared dict的lua文件
location ^~/itemlua/get {
    default_type 'application/json';
    content_by_lua_file '/usr/local/openresty/nginx/lua/itemsharedic.lua';
}
  • 然后使用itemlua url去访问验证