gpt4 book ai didi

java - JAX-WS 客户端关闭与 FIN、ACK 的 tcp 连接

转载 作者:可可西里 更新时间:2023-11-01 02:42:42 26 4
gpt4 key购买 nike

我们已经实现了 JAX-WS 客户端并面临以下问题。它是一个有状态的 session 同步流。客户端最初成功地发出了两个请求/响应

问题的 3 个不同案例

1) 在前两个请求/响应之后,我在收到第二个请求的响应后的第 6 秒和第 9 秒(两个不同的测试用例)之后发出第三个请求。在这两种情况下,从 tcpdump 我可以看到我们的客户端正在通过 [FIN,ACK] 关闭现有的 tcp 连接并为第三个请求打开一个新连接。但由于这是有状态 session ,服务器预计连接不应关闭,因此我们收到错误响应。

2) 如果我在第二次请求后的 5 秒内发出第三次请求,则会重新使用相同的 tcp 连接。

3) 如果我根本不发出第三个请求,则在 10 秒后自动(通过来自第二个请求的 [FIN,ACK],客户端关闭 tcp 连接。

基本上问题是客户端应用程序正在自行关闭 tcp 连接。我试过设置以下所有属性。但我仍然面临着同样的问题。

   BindingProvider bp = (BindingProvider)port;
Map<String, Object> context = bp.getRequestContext();
context.put(BindingProvider.SESSION_MAINTAIN_PROPERTY, true);

context.put(JAXWSProperties.CONNECT_TIMEOUT, 60000);
context.put(JAXWSProperties.REQUEST_TIMEOUT, 70000);

context.put("com.sun.xml.ws.connect.timeout", 50000);
context.put("com.sun.xml.ws.request.timeout", 50000);

context.put("javax.xml.ws.client.connectionTimeout", 60000);
context.put("javax.xml.ws.client.receiveTimeout", 70000);

我附上pcap文件的截图供大家引用。在这里你可以看到客户端在 6 秒后发出的 [FIN,ACK]。 enter image description here

我不确定是否还有其他任何我遗漏的配置。你能帮我解决这个问题吗?

版本:Java : jdk1.6.0_21

地铁:地铁/2.3

HTTP:1.1

我注意到的另一件事是,请求中有一个“Connection: keep-alive”,但服务器的响应中没有。不确定这是否是个问题

最佳答案

因为我遇到了同样的问题,所以我进行了进一步调查。我发现这是 HTTP 1.1 的默认行为。来自维基百科(persistent connection):

In HTTP 1.1, all connections are considered persistent unless declared otherwise.1 The HTTP persistent connections do not use separate keepalive messages, they just allow multiple requests to use a single connection. However, the default connection timeout of Apache httpd 1.3 and 2.0 is as little as 15 seconds2[3] and just 5 seconds for Apache httpd 2.2 and above.[4][5] The advantage of a short timeout is the ability to deliver multiple components of a web page quickly while not consuming resources to run multiple server processes or threads for too long

所以基本上发生的事情是您的客户端在空闲达到配置的时间量(连接超时)后关闭连接。 Jax-ws 默认实现 apache HttpUrlConnection它有一个预先配置的 15 秒超时。在 Weblogic 12.1.3 上运行的客户端中,以下配置对我们有效:

final BindingProvider binding = (BindingProvider) port;
final Map<String, Object> ctx = binding.getRequestContext();
ctx.put("com.sun.xml.ws.request.timeout", requestTimeOut);
ctx.put("com.sun.xml.ws.connect.timeout", connectTimeOut);

关于java - JAX-WS 客户端关闭与 FIN、ACK 的 tcp 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27484844/

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