zoukankan      html  css  js  c++  java
  • Linux 下tomcat 出现 java.lang.OutOfMemoryError: unable to create new native thread

    问题现象:

    Tomcat(8.5.13)部署了SuperMap iServer,并发用户在100左右。系统运行一段时间后,服务崩溃。异常提示

    问题分析:

    1、看到日志中的提示信息后,认为是系统内存不足导致的。于是在服务器上添加了监控脚本(如下图),每1s记录一次系统内存和tomcat内存。

    监控一段时间后,异常再次出现。从日志中并未发现内存异常

    2、内存排除后,思路转到是否是由于并发用户数太多,导致的进程数超出呢?

     1)查看linux 当前用户的资源限制参数 ulimit -a

    2)在上面这些参数中,关注得比较多的是一个进程可打开的最大文件数,即open files。系统允许创建的最大进程数量即是max user processes 这个参数。 我们可以使用 ulimit -u 4096 修改max user processes的值,但是只能在当前终端的这个session里面生效,重新登录后仍然是使用系统默认值。

    正确的修改方式是修改/etc/security/limits.d/90-nproc.conf文件中的值。先看一下这个文件包含什么:

    $ cat /etc/security/limits.d/90-nproc.conf 
    # Default limit for number of user's processes to prevent
    # accidental fork bombs.
    # See rhbz #432903 for reasoning.
    
    *          soft    nproc    4096

    我们只要修改上面文件中的4096这个值,即可。

    经过排查,确实是由于服务器当前用户设置的最大进程数设置太小导致的无法创建进程,崩溃。

    参考:http://www.linuxidc.com/Linux/2011-03/33121.htm

    http://www.cnblogs.com/billyxp/archive/2013/04/03/2998079.html

    linux 查看当前进程:http://os.51cto.com/art/201101/244090.htm

    http://www.linuxidc.com/Linux/2015-01/111270.htm

  • 相关阅读:
    Redis数据库
    python的web运用
    python对 if __name__=='__main__'的理解
    python的函数
    python的四种内置数据结构
    python的循环和选择
    关于oracle设置主键自增的问题
    用HttpClient和用HttpURLConnection做爬虫发现爬取的代码少了的问题
    ORACLE not available如何解决
    集合(下)
  • 原文地址:https://www.cnblogs.com/yaohuimo/p/7156320.html
Copyright © 2011-2022 走看看