首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Kong:客户端关闭保持连接

Kong:客户端关闭保持连接
EN

Stack Overflow用户
提问于 2019-06-24 14:45:22
回答 1查看 1.4K关注 0票数 3

我正在为kong编写一个自定义插件。该插件将根据我的服务器转换请求/响应。我去叫[info] 27#0: *588 client <x> closed keepalive connection

经过一些调试后,我发现每当我使用转换后的响应设置ngx.arg[1]时,都会发生错误。我已经使用了孔令辉提供的现有response-transformer插件。

这是kong body_filter函数的主体:

代码语言:javascript
复制
local ctx = ngx.ctx
  local chunk, eof = ngx.arg[1], ngx.arg[2]

  ctx.rt_body_chunks = ctx.rt_body_chunks or {}
  ctx.rt_body_chunk_number = ctx.rt_body_chunk_number or 1

  if eof then
    local someChunks = concat(ctx.rt_body_chunks)
    local aBody = responseTransformer.transform(theConf, someChunks)
    aBody = unEscapeString(aBody)
    ngx.arg[1] = aBody or someChunks
  else
    ctx.rt_body_chunks[ctx.rt_body_chunk_number] = chunk
    ctx.rt_body_chunk_number = ctx.rt_body_chunk_number + 1
    ngx.arg[1] = nil
  end

我在本地虚拟服务器上运行了相同的插件。它工作正常。但是当我代理到我的实际服务器时,我得到了closed keepalive connection错误。

从孔氏日志中,我可以看到响应得到了正确的转换。

使用curl,我得到了大约一半的响应正文。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-06-24 17:00:36

找到原因了。服务器正在发送Content-Length标头。在重写正文期间,这一点保持不变。因此,在传送完整内容之前,连接正在关闭。

为了解决这个问题,我必须清除header_filter函数中的Content-Length头:

kong.response.clear_header("Content-Length")

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56731106

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档