Centos系统下载大全 | Redhat系统下载大全 | Windows2012系统下载大全 | Windows2008系统下载大全| CMS教程 | 网站地图 51运维网-专注Linux/Unix系统安全运维!
当前位置:51运维网 > 架构 > Nginx > 正文

drizzle lua 数据传递(ngx.location.capture)

时间:2014-06-27 19:35 来源:网络整理 作者:51ou.com 阅读:

经常使用PHP开发的WEB开发人员,刚刚转到NGINX+DRIZZLE开发环境,开始估计会遇到LUA如何获取DRIZZLE+MYSQL返回数据的问题,下面给出我的一些经验。
首先修改NGINX的配置文件
location /mysql {
set $name $1;
set_quote_sql_str $quote_name $name;
set $sql "SELECT * FROM crawl WHERE id=3";
drizzle_query $sql; drizzle_pass mysql; rds_json on;
}

curl localhost:8080/mysql 返回的结果:[{"id":3,"url_id":"100","url_type":"item","date":"0000-00-00","url":"http://item.taobao.com/item.htm?id=100","status":0,"failures":0,"start_date":0,"unit_id":54848}]

然后在后面加入:
        location /lua{
            content_by_lua '
                local res = ngx.location.capture("/mysql")
                ngx.say("data: " .. res.body)
            ';
        }
curl localhost:8080/lua 返回的结果:data: [{"id":3,"url_id":"100","url_type":"item","date":"0000-00-00","url":"http://item.taobao.com/item.htm?id=100","status":0,"failures":0,"start_date":0,"unit_id":54848}]

最后大家也就都能猜到了
        location /luafile {
            content_by_lua_file /usr/local/openresty/nginx/html/test.lua;
        }
test.lua
local res = ngx.location.capture("/mysql")
ngx.say("data: " .. res.body)

搞定:curl localhost:8080/luafile 返回的结果:data: [{"id":3,"url_id":"100","url_type":"item","date":"0000-00-00","url":"http://item.taobao.com/item.htm?id=100","status":0,"failures":0,"start_date":0,"unit_id":54848}]

感谢您对【51运维网 http://www.51ou.com/】的支持,我们为您免费提供《drizzle lua 数据传递(ngx.location.capture)》技术文章,《drizzle lua 数据传递(ngx.location.capture)》详细使用和说明,有时《drizzle lua 数据传递(ngx.location.capture)》可能不完善、敬请谅解!如果《drizzle lua 数据传递(ngx.location.capture)》有错误请给我们留言,我们将尽快修复文章错误,如果您觉得本站不错,请分享给周围的朋友!谢谢!

顶一下
(0)
0%
踩一下
(0)
0%
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
验证码:点击我更换图片