lua-resty-http:连接方法澄清

我正在实现一个需要进行HTTP请求以检索信息并与上游服务共享的kong插件。

有一个名为lua-resty-http的优秀库可用于进行HTTP请求。

包含所需信息的服务已在代理后面配置,并且匹配路径为:/endpoint-providing-info.

目标是依靠代理能力,避免不相关的问题,而不必解析具有一些特定形式的主机名,这不是本问题的相关内容。

通过尝试,我成功地通过执行以下操作来实现所需的行为:

local ok,err = http_client:connect("127.0.0.1",ngx.var.server_port)
if not ok and err then return nil' there was a failure opening a connection: ' .. err
local res,err = http_client:request({
    method = 'GET'path = '/endpoint-providing-info'
})
//解析响应,等等...

请求被路由到上游服务并按预期工作。

我的主要问题是以下内容:

通过连接到localhost,我假设当前的Nginx节点正在处理请求。 这会影响性能吗? 直接连接到集群是否更好/可能?

点赞
用户2060502
用户2060502

我假设您为当前的nginx配置了一个匹配/endpoint-providing-info的位置,使用代理模块并为群集配置了上游。

如果您使用lua-resty-http

优点 - 您可以使用body_reader - 一个可以以流式迭代方式读取正文的迭代器函数。

缺点 - 您的请求将通过内核边界(环回接口)。

另一种可能是使用ngx.location.capture API发出子请求

优点 - 子请求只模仿HTTP接口,但没有额外的HTTP / TCP流量或IPC涉及。一切都在C级别内部高效地工作。

缺点 - 这是完全缓冲的方法,对于大型响应效率不高。

更新 - 我的见解:

如果您希望上游服务器提供大型响应-lua-resty-http是您的选择。

如果您希望上游服务器提供大量小的响应 - 应该使用ngx.location.capture

2018-05-02 09:40:32