openresty总结

协程

1.例如当获取的数据没有前后依赖关系时,可以使用ngx.thread.spawn和ngx.thread.wait同时从数据库不同的库、表或者不同来源(mysql,redis等)获取数据。
https://github.com/openresty/lua-nginx-module#ngxthreadspawn
https://github.com/openresty/lua-nginx-module#ngxthreadwait
2.假如从不同的location获取数据时,可以使用ngx.location.capture_multi并发获取
3.ngx.ctx.foo中变量foo可以跨越一个请求的多个阶段(rewrite,access,content等),但是子请求拥有独立的ngx.ctx表,并不共享。ngx.location.capture中附加的参数中添加{ctx = ngx.ctx},可设置为父子请求共享同一个 ngx.ctx 表。

posted @ 2017-07-19 19:46  mentalidade  阅读(413)  评论(0编辑  收藏  举报