Nginx + Lua + 共享内存实现动态查询(简单例子)

原创 2013年12月03日 18:07:08

Nginx 配置。

    lua_package_path "/usr/local/share/luajit-2.0.2/jit?.lua;;";
    lua_shared_dict devicedb 45m; 
        location /query {
           default_type 'text/plain';
           content_by_lua '
                    local args = ngx.req.get_uri_args()
                    local devicetype = args["device"]
                    local devicedb = ngx.shared.devicedb
                    local res = devicedb:get(devicetype)

                    ngx.say(res)
               ';
        }

        location /update {
            default_type 'text/plain';
            content_by_lua '
                    local devicedb = ngx.shared.devicedb

                    for item in io.lines("/usr/local/nginx-1.4.2/data/rule.txt") do
                        _,_,device_type, device_rule = string.find(item, "^(%a+)--(%a+)$")
                        devicedb:set(device_type,device_rule)
                    end

                    ngx.say("ok")            
               ';
        }

rule.txt文件格式。

SAMSUNG--samRule
APPLE--appRule
XIAOMI--xiaRule


步骤1,访问/update,更新共享内存devicedb

步骤2,访问query?device=XIAOMI,返回xiaRule

步骤3,修改rule.txt,将xiaRule改为xiaRuleaaaa

步骤4,访问/update,更新共享内存devicedb

步骤5,访问query?device=XIAOMI,返回xiaRuleaaaa


内网响应时间在5~10ms。


参考文章:

http://my.oschina.net/766/blog/158972

http://haili.me/archives/722.html



相关文章推荐

ngx_lua模块中的共享内存字典项API

在ngx_lua模块中使用共享内存字典项相关API的前提条件是已经使用

NGINX 结合 lua 动态修改upstream

具体思路是:  1 > 利用lua中 "lua_shared_dict" 指令开辟一个共享内存空间; 2> 通过API动态根据key值&参数修改 upstream  (这里使用 host 作为key)...

ngx映射到lua模块函数变量一览

ngx.arg[1] 脚本参数 ngx.var['arg_a'] 取queryString的参数a #/nginx_var?a=hello,worl...

ngx_lua模块中的共享内存字典项API

在ngx_lua模块中使用共享内存字典项相关API的前提条件是已经使用lua_shared_dict命令定义了一个字典项对象,该命令的具体用法为:   语法:lua_shared_dict ...

使用lua语言做高并发限流

lua语言介绍        Lua[1]  是一个小巧的脚本语言。是巴西里约热内卢天主教大学(Pontifical Catholic University of Rio de Janeiro)里的...

用Luajit玩Linux共享内存

1. shmtest_wirte.lua  ffi = require 'ffi'ffi.cdef[[   int shmget(int key,int size,int flag);   void ...
  • fxsjy
  • fxsjy
  • 2011年03月25日 16:08
  • 1273

nginx+redis+lua 共享内存

环境:nginx + redis 起因:项目中有些接口是需要客户端轮询去访问的,这样所造成的后果就是这些接口一直占用redis内存,造成其他接口效率的降低(如果此时正好赶上JOB运行,redis的消...

ngx映射到lua模块函数变量一览

ngx.arg[1]                脚本参数 ngx.var['arg_a']            取queryString的参数a #/nginx_var?a=hello,wor...
  • joeyon
  • joeyon
  • 2015年07月03日 18:48
  • 4631

Nginx + Lua + 共享内存实现动态查询(简单例子)

Nginx 配置。 [plain] view plain copy lua_package_path "/usr/local/share/luajit-2.0.2/jit...

用lua扩展你的Nginx(写的非常好)

一. 概述 Nginx是一个高性能,支持高并发的,轻量级的web服务器。目前,Apache依然web服务器中的老大,但是在全球前1000大的web服务器中,Nginx的份额为22.4%。Nginx采用...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Nginx + Lua + 共享内存实现动态查询(简单例子)
举报原因:
原因补充:

(最多只允许输入30个字)