如何在Web服务中为StreamingOutput保持客户端和服务器连接的活动

时间:2018-05-29 11:07:00

标签: java web-services jersey jersey-client

我的网络服务代码

final StreamingOutput stream = new StreamingOutput() {
  @Override
  public void write(final OutputStream out) {
    dao.getData(
        query,
        new SdmxObserver(writerFactory.getDataWriter(sdmxFormat, out, properties), request
            .getRemoteAddr(), request.getHeader("User-Agent"), query.toString(), sdmxFormat
            .toString(), query.getlist()));
  }
};
res = Response.ok(stream, MediaType.valueOf("application/vnd.sdmx.genericdata+xml;version=2.1"))
                .cacheControl(cc).lastModified(lastModified).header("Vary", "Accept,Accept-Encoding").build();
return res;

用于检索数据的数据库调用耗时很长,因此当我们使用代理时,它有2分钟的时间,因此数据不是来自数据库,并且显示连接超时。虽然我们使用StreamingOutput然后为什么不发生流式传输以保持连接活着?此外,如果我们绕过代理,那么我们就可以从网络服务中获得数据。

但我们无法更改代理设置,也需要在使用或不使用代理的情况下使用该应用程序。

1 个答案:

答案 0 :(得分:1)

您的代理服务器很可能只是在配置超时后终止连接,无论您是否正在传输数据。如果您想知道,Connection: keep-alive标头仅表示可以为多个请求/响应(RFC7230)重用相同的连接,则不应该控制单个连接的超时。

尝试与代理管理员讨论:

  • 设置代理理解的标题(可能是Keep-alive: timeout=10000,但也可能是完全不同的,或者可能根本不可能)
  • 增加代理超时配置

如果这样做不成功,您可能需要重新考虑您的设计并采取不同的方法,例如Spring Data + pageable resources,或者,如果您觉得勇敢,则使用Spring Integration + Splitter pattern进行异步处理。