ingress-nginx-helm/rootfs/etc/nginx/lua/balancer/chash.lua
2018-08-16 13:03:41 -04:00

20 lines
548 B
Lua

local balancer_resty = require("balancer.resty")
local resty_chash = require("resty.chash")
local util = require("util")
local _M = balancer_resty:new({ factory = resty_chash, name = "chash" })
function _M.new(self, backend)
local nodes = util.get_nodes(backend.endpoints)
local o = { instance = self.factory:new(nodes), hash_by = backend["upstream-hash-by"] }
setmetatable(o, self)
self.__index = self
return o
end
function _M.balance(self)
local key = util.lua_ngx_var(self.hash_by)
return self.instance:find(key)
end
return _M