3

我在java中使用多线程同时扫描不同的URL。如果请求时间总和超过 100,000,则存在错误。我已经关闭了我应该关闭的。这是我的 servlet 中的代码

private String proyGetHttp(String url) throws ParseException, IOException,
            InterruptedException {

        String content = "";
        getMethod = new HttpGet(url);
        HttpResponse response = null;
        HttpEntity httpEntity = null;
        boolean success = false;
        while (!success) {
            System.out.println("url:" + url + ",connect...");
            try {
                response = client.execute(getMethod);
                httpEntity = response.getEntity();
                StringBuffer sb = new StringBuffer();
                if (httpEntity != null) {
                    BufferedReader in = null;
                    InputStream instream = httpEntity.getContent();
                    try {
                        in = new BufferedReader(new InputStreamReader(instream));
                        String lineContent = "";
                        while(lineContent != null){
                            sb.append(lineContent);
                            lineContent = in.readLine();
                        }

                    } catch (Exception ex)
                        getMethod.abort();
                        throw ex;
                    } finally {
                        // Closing the input stream will trigger connection release
                        try { instream.close(); in.close();} catch (Exception ignore) {}
                    }
                }
                content = sb.toString();
                success = true;
                System.out.println("connect successfully...");
            } catch (Exception e) {
                e.printStackTrace();
                getMethod.abort();
                System.out.println("connect fail, please waitting...");
                Thread.sleep(sleepTime);
            }finally{
                getMethod.releaseConnection();
            }
        }
        return content;
    }

这里的代码创建默认客户端

        PoolingClientConnectionManager cm = new PoolingClientConnectionManager();
        cm.setMaxTotal(100);
        DefaultHttpClient client = null;
        client = new DefaultHttpClient(cm);
        client.getParams().setParameter("http.protocol.cookie-policy", CookiePolicy.BROWSER_COMPATIBILITY);
        client.getParams().setParameter(HttpConnectionParams.CONNECTION_TIMEOUT, 5000);
4

1 回答 1

9

我有同样的问题,我找到了解决方法。此超时是由于连接泄漏。就我而言,我使用的是 httpDelete 方法而不是使用响应。相反,我正在检查响应的状态。

解决方法是,需要使用响应实体。为了确保系统资源的正确释放,必须关闭与实体关联的内容流。

所以我使用EntityUtils.consumeQuietly(response.getEntity());了它来确保实体内容被完全消耗并且内容流(如果存在)被关闭。

于 2014-04-02T20:21:27.147 回答