Java NIO 操作总结

问题:

  1、Java NIO 出现大量CLOSE_WAIT或TIME_WAIT的端口无法释放

    CLOSE_WAIT:

      参考:http://my.oschina.net/geecoodeer/blog/191774、http://blog.csdn.net/ruixj/article/details/1871979

      解决:检查代码可发现,一端的socket调用了close,但是另外一端的socket没有调用close,于是在另外一端加上了socket.close()函数,使得CLOSE_WAIT消失,TIME_WAIT出现。

        一般来说,到了TIME_WAIT就是比较正常的情况了,下面是TCP状态转换图:

        

        close操作相当于:(操作/A操作后状态/B操作后状态)

        A:我不想说了,但是我可以听到你的(close,发送FIN/A:FIN_WAIT_1/B:ESTABLEISHED)

        B:点头(接收FIN,发送ACK/A:FIN_WAIT_1/B:CLOSE_WAIT)

        A:点头(接收ACK/A:FIN_WAIT_2/B:CLOSE_WAIT)

        B:我也不想说了,我在有限时间内还可以听到你的(close,发送FIN/A:FIN_WAIT_2/B:TIME_WAIT)

        A:点头(接收FIN,发送ACK/A:TIME_WAIT/B:TIME_WAIT)

        B:点头(接收ACK/A:TIME_WAIT/B:CLOSED)

    TIME_WAIT:

      参考:http://my.oschina.net/geecoodeer/blog/191774、http://www.blogjava.net/cooperzh/archive/2011/12/20/366884.html

      解决:socket.setReuseAddress(true);

 

  2、Java NIO 多线程程序长时间运行时出现“打开的文件过多”错误

    参考:无

    解决:

      1)ls /proc/进程号/fd,发现超多被占用的文件描述符

      2)检查代码,查看一下哪里没有关闭SocketChannel和Selector(特别是Selector!由于是多线程,子线程打开的资源忘记关闭会遗留并造成悲剧啊:()

posted on 2014-08-20 11:17  DeeFOX  阅读(1143)  评论(0编辑  收藏  举报

导航