Java套接字连接在读取最后一行之前挂起60秒

时间:2013-01-13 11:49:07

标签: java sockets

我已经通过Java套接字手动开发了一个soap连接(这是一个非常简单的soap请求,Axis给出了很多构建问题)。

为了实现这一点,我基本上复制了我从Soap UI中获取的HTTP头,并编写了以下内容:

String hostname = "aaaaa";
int port = 11111;
InetAddress  addr = InetAddress.getByName(hostname);
Socket sock = new Socket(addr, port);
sock.setSoTimeout(100000);
BufferedWriter  wr = new BufferedWriter(new OutputStreamWriter(sock.getOutputStream(),"UTF-8"));
wr.write("POST " + "http://aaaa:11111/servicePath" + " HTTP/1.1\r\n");
wr.write("Host: aaaaa:11111\r\n");
wr.write("Accept-Encoding: gzip,deflate\r\n");
wr.write("Content-Length: " + soapXml.length() + "\r\n");
wr.write("Content-Type: text/xml; charset=\"UTF-8\"\r\n");
//wr.write("Connection: Keep-Alive\r\n");
wr.write("SOAPAction: \"/someSoapAction\"\r\n");
wr.write("User-Agent: Apache-HttpClient/4.1.1 (java 1.5)\r\n");
wr.write("\r\n");
wr.write(soapXml);
wr.flush();

请求成功,这意味着我从服务中获得了我期望的响应。 例如,当我手写“soapXml”一些无效参数时,我得到一个500错误回复XML解释问题,如果我正确设置一切我得到一个200 OK与标题后面的xml正文。

问题是在200OK的情况下,套接字在读取HTTP正文之前会挂起60秒。

它基本上读取完整的标题,然后等待60秒,然后(我认为一些协议超时)最终读取xml正文。

以下是我阅读回复的代码:

String line;
BufferedReader rd = new BufferedReader(new java.io.InputStreamReader(sock.getInputStream(),"UTF-8"));
while ((line = rd.readLine()) != null) { 
            i++;
            LOG.debug("cycle: "+i+" -------- "+line);
                     //after printing the header, it hangs 60 seconds before printing the follwing XML  
            if ((line.length() >0) && (line.charAt(0) == '<'))
            {
                responseXML = line;
            }
}

以下是200 OK标题示例:

HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
Content-Type: text/xml;charset=utf-8
Content-Length: 1052
Date: Sun, 13 Jan 2013 08:33:45 GMT -- hanging 60 seconds here
-- blank line
<?xml version="1.0" encoding="UTF-8"?>................</SOAP-ENV:Envelope>

有人遇到过这种情况吗?请注意,这显然不是服务器问题,因为使用soap UI会立即提供答案。

谢谢

2 个答案:

答案 0 :(得分:0)

服务器保持连接打开以保持HTTP保持活动状态,显然是60秒超时。要么更改为HTTP 1.0,要么记下返回的Content-length标头,并停止读取那么多字节。

答案 1 :(得分:0)

服务器环境变化(提供了新机器)解决了这个问题。

现在200OK的响应时间也低于1秒。

不幸的是,我没有关于环境技术堆栈的任何细节。无论如何,谢谢你的帮助。