這期內容當中小編將會給大家帶來有關怎么在nginx中使用ctx實現數據共享,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
環境: init_worker_by_lua, set_by_lua, rewrite_by_lua, access_by_lua, content_by_lua, header_filter_by_lua, body_filter_by_lua, log_by_lua, ngx.timer., balancer_by_lua
location /test {
rewrite_by_lua_block {
ngx.ctx.foo = 76
}
access_by_lua_block {
ngx.ctx.foo = ngx.ctx.foo + 3
}
content_by_lua_block {
ngx.say(ngx.ctx.foo)
}
}訪問 GET /test 輸出
79
也就是說,ngx.ctx.foo 條目跨越一個請求的 rewrite (重寫),access (訪問),和 content (內容) 各處理階段保持一致。
每個請求,包括子請求,都有一份自己的 ngx.ctx 表。例如:
location /sub {
content_by_lua_block {
ngx.say("sub pre: ", ngx.ctx.blah)
ngx.ctx.blah = 32
ngx.say("sub post: ", ngx.ctx.blah)
}
}
location /main {
content_by_lua_block {
ngx.ctx.blah = 73
ngx.say("main pre: ", ngx.ctx.blah)
local res = ngx.location.capture("/sub")
ngx.print(res.body)
ngx.say("main post: ", ngx.ctx.blah)
}
}訪問 GET /main 輸出
main pre: 73
sub pre: nil
sub post: 32
main post: 73
這里,在子請求中修改 ngx.ctx.blah 條目并不影響父請求中的同名條目,因為它們各自維護不同版本的 ngx.ctx.blah。
內部重定向將摧毀原始請求中的 ngx.ctx 數據 (如果有),新請求將會有一個空白的 ngx.ctx 表。例如,
location /new {
content_by_lua_block {
ngx.say(ngx.ctx.foo)
}
}
location /orig {
content_by_lua_block {
ngx.ctx.foo = "hello"
ngx.exec("/new")
}
}訪問 GET /orig 將輸出
nil
而不是原始的 "hello" 值。
任意數據值,包括 Lua 閉包與嵌套表,都可以被插入這個“魔法”表,也允許注冊自定義元方法。
也可以將 ngx.ctx 覆蓋為一個新 Lua 表,例如,
ngx.ctx = { foo = 32, bar = 54 }
當用在 init_worker_by_lua* 環境中,這個表與當前 Lua 句柄生命周期相同。
ngx.ctx 表查詢需要相對昂貴的元方法調用,這比通過用戶自己的函數參數直接傳遞基于請求的數據要慢得多。所以不要為了節約用戶函數參數而濫用此 API,因為它可能對性能有明顯影響。
而且由于元方法“魔法”,不要在 lua 模塊級別試圖使用 "local" 級別的 ngx.ctx ,例如 worker-level data sharing。下面示例是糟糕的:
-- mymodule.lua
local _M = {}
-- 下面一行的 ngx.ctx 是屬于單個請求的,但 ctx 變量是在 Lua 模塊級別
-- 并且屬于單個 worker 的。
local ctx = ngx.ctx function _M.main() ctx.foo = "bar" end return _M
應使用下面方式替代:
-- mymodule.lua
local _M = {}
function _M.main(ctx)
ctx.foo = "bar"
end
return _M上述就是小編為大家分享的怎么在nginx中使用ctx實現數據共享了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。