zoukankan      html  css  js  c++  java
  • Too many open files

    本文转自:http://www.cnblogs.com/feiling/archive/2012/12/02/2798098.html

    参考文章:http://www.cnblogs.com/challengeof/p/4276659.html

    打开的文件过多,一般来说是由于应用程序对资源使用不当造成,比如没有及时关闭Socket或数据库连接等。但也可能应用确实需要打开比较多的文件句柄,而系统本身的设置限制了这一数量。

    异常 1  
    java.net.SocketException: Too many open files

        at java.net.PlainSocketImpl.accept(Compiled Code) 
        at java.net.ServerSocket.implAccept(Compiled Code) 
        at java.net.ServerSocket.accept(Compiled Code) 
        at weblogic.t3.srvr.ListenThread.run(Compiled Code) 

    异常 2 
    java.io.IOException:打开的文件过多

        at java.lang.UNIXProcess.forkAndExec(Native Method)
        at java.lang.UNIXProcess.(UNIXProcess.java:54)
        at java.lang.UNIXProcess.forkAndExec(Native Method)
        at java.lang.UNIXProcess.(UNIXProcess.java:54)
        at java.lang.Runtime.execInternal(Native Method)
        at java.lang.Runtime.exec(Runtime.java:551)
        at java.lang.Runtime.exec(Runtime.java:477)
        at java.lang.Runtime.exec(Runtime.java:443)

    ...

    第一个异常在错误影响到基础 TCP 协议时抛出,而第二个异常则在错误影响到 I/O 操作时抛出。

    文件打开数过多最坏的情况可以使系统崩溃,到时候只能是重起服务器了。

    原因:   

        操作系统的中打开文件的最大句柄数受限所致,常常发生在很多个并发用户访问服务器的时候.因为为了执行每个用户的应用服务器都要加载很多文件(new一个socket就需要一个文件句柄),这就会导致打开文件的句柄的缺乏.

    解决: 

    • 尽量把类打成jar包,因为一个jar包只消耗一个文件句柄,如果不打包,一个类就消耗一个文件句柄.
    • java的垃圾回收不能关闭网络连接打开的文件句柄,如果没有执行close()(例如:java.net.Socket.close())则文件句柄将一直存在,而不能被关闭.你也可以考虑设置socket的最大打开数来控制这个问题.
    •  对操作系统做相关的设置,增加最大文件句柄数量。
      1. Linux
        在 Linux内核2.4.x中需要修改源代码,然后重新编译内核才生效。编辑Linux内核源代码中的 include/linux/fs.h文件,将 NR_FILE 由8192改为65536,将NR_RESERVED_FILES 由10 改为 128。编辑fs/inode.c 文件将MAX_INODE 由16384改为262144。或者编辑 /etc/sysctl.conf  文件增加两行 fs.file-max = 65536 和 fs.inode-max = 262144 。一般情况下,系统最大打开文件数比较合理的设置为每4M物理内存256,比如256M.可以用lsof -p <pid of process>看打开的文件句柄数.
      2. Windows
        最大文件句柄是16,384,你在任务管理器的性能这一项中可以看到当前打开的句柄数.


    服务器端修改:

    查看系统允许打开的最大文件数

    #cat /proc/sys/fs/file-max

    查看每个用户允许打开的最大文件数

    ulimit -a

    发现系统默认的是open files (-n) 1024,问题就出现在这里。

    在系统文件/etc/security/limits.conf中修改这个数量限制,

    在文件中加入内容:(*是指你的用户名)

    * soft nofile 65536 
    * hard nofile 65536

    在 /etc/pam.d/common-session 加上这一行:

    session required  pam_limits.so
    否则在 /etc/security/limits.conf上的配置不会生效.

    还有注销再登录,这些配置才能生效!

    另外方法:
    1.使用ps -ef |grep java   (java代表你程序,查看你程序进程) 查看你的进程ID,记录ID号,假设进程ID为12
    2.使用:lsof -p 12 | wc -l    查看当前进程id为12的 文件操作状况
        执行该命令出现文件使用情况为 1052
    3.使用命令:ulimit -a   查看每个用户允许打开的最大文件数
        发现系统默认的是open files (-n) 1024,问题就出现在这里。
    4.然后执行:ulimit -n 4096

         将open files (-n) 1024 设置成open files (-n) 4096

    这样就增大了用户允许打开的最大文件数

  • 相关阅读:
    javaWeb接口开发
    .NET设计模式(4):建造者模式(Builder Pattern)(转载)
    .net数据库连接池(转载)
    系统操作日志设计(转载)
    系统操作日志设计-代码实现(转载)
    GOF对Builder模式的定义(转载)
    Javascript中的对象和原型(一)(转载)
    Javascript中的对象和原型(二)(转载)
    Javascript中的对象和原型(三)(转载)
    服务器安全设置(转载)
  • 原文地址:https://www.cnblogs.com/Jtianlin/p/4355961.html
Copyright © 2011-2022 走看看