http://blog.sina.com.cn/s/blog_56beadc60100j9zu.html

今天自己写了一个压力测试的小程序,同时启100个线程,每个线程都串行地访问应用服务器上的一个jsp页面200次。在程序运行了一会儿以后,问题来了:

  1. java.net.SocketException: No buffer space available (maximum connections reached?): connect
  2. at java.net.PlainSocketImpl.socketConnect(Native Method)
  3. at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
  4. at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
  5. at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
  6. at java.net.Socket.connect(Socket.java:516)
  7. at java.net.Socket.connect(Socket.java:466)
  8. at sun.net.NetworkClient.doConnect(NetworkClient.java:157)
  9. at sun.net.www.http.HttpClient.openServer(HttpClient.java:365)
  10. at sun.net.www.http.HttpClient.openServer(HttpClient.java:477)
  11. at sun.net.www.http.HttpClient.<init>(HttpClient.java:214)
  12. at sun.net.www.http.HttpClient.New(HttpClient.java:287)
  13. at sun.net.www.http.HttpClient.New(HttpClient.java:299)
  14. at sun.net.www.protocol.http.HttpURLConnection.getNewHttpClient(HttpURLConnection.java:796)
  15. at sun.net.www.protocol.http.HttpURLConnection.plainConnect(HttpURLConnection.java:748)
  16. at sun.net.www.protocol.http.HttpURLConnection.connect(HttpURLConnection.java:673)
  17. at sun.net.www.protocol.http.HttpURLConnection.getOutputStream(HttpURLConnection.java:840)

到网上查了查,应该是资源耗尽了,但是没有找到解决的方法。
程序片断代码如下:

  1. for (int j = 0; j < 200; j++) {
  2. long beginTime = System.currentTimeMillis();
  3. URL url = new URL("...");
  4. HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
  5. httpURLConnection.setDoOutput(true);
  6. httpURLConnection.setRequestMethod("POST");
  7. OutputStream os = httpURLConnection.getOutputStream();
  8. keywordNum = random.nextInt(myKeywords.length);
  9. os.write(("keyword=" + myKeywords[keywordNum]).getBytes("UTF8"));
  10. os.flush();
  11. os.close();
  12. int i = 0;
  13. int contentLength = 0;
  14. contentLength = httpURLConnection.getContentLength();
  15. long endTime = System.currentTimeMillis();
  16. System.out.println("Thread '" + name + "' search keyword '" + myKeywords[keywordNum] + "' and get content in " + (endTime - beginTime) + " Millis, length=" + contentLength);
  17. }

后来想了想,既然资源没释放,释放就可以了。查了一下HttpURLConnection有个disconnect方法,但是加上后也没有用。再找,jdk的docs里说,HttpURLConnection这个对象关掉相关的InputStream和OutputStream可以释放掉相关资源,于是试了下,在contentLength = httpURLConnection.getContentLength();这行后面又加了2行:

  1. InputStream is = httpURLConnection.getInputStream();
  2. is.close();

问题解决了。
原来只是知道如果不调用httpURLConnection的getContentLength或其它get方法,请求是不会提交的,一般如果不需要也不会去调getInputStream,没想到还有个释放资源的问题。

==============================================================

简单的概括下释放httpUrlConnection的资源就是:

调用HttpURLConnection的disConnecn方法,还要关掉关联的inputStream和outputStream

使用HttpURLConnection时遇到的资源未释放的问题的更多相关文章

  1. 解决切换场景时NGUI图集资源未释放的问题

    使用unity3d编辑器,在切换场景的时候.NGUI的图集没有释放造成内存不足游戏闪退的问题. 默认情况下,unity3d切换场景之后会释放不用的内存,即内部会调用Resources.UnloadUn ...

  2. redis资源未释放引发的问题

    一.redis资源未释放的起因: N年前,在修改一个古老程序时,不小心把redis释放的这块给干掉了, if (jedis != null) { if (!isInProcess) { jedis.d ...

  3. 图层损坏 E/ArcGIS﹕ The map or layer has been destroyed or recycled. 资源未释放

    看到论坛上有个网友和我一样的问题: The map or layer has been destroyed or recyled t Hello, I have a problem when the ...

  4. mysql优化, 删除数据后物理空间未释放(转载)

    mysql优化, 删除数据后物理空间未释放(转载) OPTIMIZE TABLE 当您的库中删除了大量的数据后,您可能会发现数据文件尺寸并没有减小.这是因为删除操作后在数据文件中留下碎片所致.OPTI ...

  5. c++继承构造子类调用父类构造函数的问题及关于容器指针的问题及当容器里储存指针时,记得要手动释放

    看下面的一个问题: class Person { private: string name; public: Person(const string& s=""){ nam ...

  6. 关于mysql 删除数据后物理空间未释放(转载)

    转自 关于mysql 删除数据后物理空间未释放(转载) - NETDATA - 博客园http://www.cnblogs.com/shawnloong/archive/2013/02/07/2908 ...

  7. jsch连接sftp后连接未释放掉问题排查

    项目中通过jsch中的sftp实现上传下载文件.在压测过程中,由于调用到sftp,下载文件不存在时,系统不断抛出异常,内存飙升,逐渐把swap区也占满,通过top监控未发现占用内存的进程,通过查找ss ...

  8. 关于在打包Jar文件时遇到的资源路径问题(二)

    在关于<关于在打包Jar文件时遇到的资源路径问题(一)>中,以及描述了当资源与可执行JAr分离时的资源路径代码的编写问题,后来想了想,为什么将<Java核心技术卷一>中的程序1 ...

  9. 关于在打包Jar文件时遇到的资源路径问题(一)

    当我们将程序写好,并进行打包成Jar文件时,通常都带有各种资源,这些资源可以是图像或者声音文件,也可以是别的如文本文件或二进制文件等,这些资源都和代码密切相关.例如在一个JPanel类上显示一些可能变 ...

随机推荐

  1. linux 命令 随笔

    1 查找命令 which (寻找执行档) :这个指令是根据PATH这个环境变量所规范的路径,去搜寻执行档的档名,所以,重点是找出执行档而已,which 后面接的是完整档名,也就说执行文件 wherei ...

  2. centos7 MFS drbd keepalived

    环境: centos7.3 + moosefs 3.0.97 + drbd84-utils-8.9.8-1 + keepalived-1.2.13-9 工作原理: 架构图: 节点信息: 节点名     ...

  3. <<APUE>> 编译方法

    /********************************************************************************第0种-最简单实用********** ...

  4. 用过的sql 工具

    sequel pro 港优创新 php myadmin 腾讯

  5. Spring AOP的注解方式实现

    spring也支持注解方式实现AOP,相对于配置文件方式,注解配置更加的轻量级,配置.修改更加方便. 1.开启AOP的注解配置方式 <!-- 开启aop属性注解 --> <aop:a ...

  6. python 使用selenium和requests爬取页面数据

    目的:获取某网站某用户下市场大于1000秒的视频信息 1.本想通过接口获得结果,但是使用post发送信息到接口,提示服务端错误. 2.通过requests获取页面结果,使用html解析工具,发现麻烦而 ...

  7. hashmap引起死循环

    今天开发环境压测的时候出现cpu用满了情况,看线程堆栈,一堆线程都停留在org.apache.commons.collections4.map.AbstractHashedMap.put(Abstra ...

  8. 1073 Scientific Notation (20 分)

    1073 Scientific Notation (20 分) Scientific notation is the way that scientists easily handle very la ...

  9. 阿里云内网和公网NTP服务器和其他互联网基础服务时间同步服务器

    阿里云为云服务器ECS提供了内网NTP服务器,对于阿里云以外的设备,阿里云同时提供了 公网NTP服务器,供互联网上的设备使用. 内网和公网NTP服务器 以下为阿里云提供的内网和公网NTP服务器列表. ...

  10. Hadoop2.0构成之HDFS2.0

    HDFS2.0之HA 主备NameNode: 1.主NameNode对外提供服务,备NameNode同步主NameNode元数据,以待切换: 2.主NameNode的信息发生变化后,会将信息写到共享数 ...