drizzle lua 數據傳遞(ngx.location.capture)


經常使用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}]


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM