gpt4 book ai didi

java - 如何在 StreamingOutput 的 Web 服务中保持客户端和服务器连接处于 Activity 状态

转载 作者:行者123 更新时间:2023-12-02 11:11:32 28 4
gpt4 key购买 nike

我的网络服务代码

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 分钟,因此由于数据在 2 分钟内没有来自数据库,因此显示连接超时。虽然我们使用了 StreamingOutput 那么为什么流式传输没有发生以保持连接处于 Activity 状态?另外,如果我们绕过代理,那么我们就可以从网络服务成功获取数据。

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

最佳答案

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

尝试与您的代理管理员讨论:

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

如果这不起作用,您可能需要重新考虑您的设计并采取不同的方法,例如 Spring Data + pageable resources或者,如果您有勇气,可以使用 Spring Integration + Splitter pattern 进行异步处理。 .

关于java - 如何在 StreamingOutput 的 Web 服务中保持客户端和服务器连接处于 Activity 状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50582838/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com