• 技术文章 >运维 >linux运维

    Linux 下tomcat错误分析

    巴扎黑巴扎黑2017-07-21 16:48:42原创1044
    问题现象:

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

    php入门到就业线上直播课:进入学习

    问题分析:

    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这个值,即可。

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

    参考:


    linux 查看当前进程:

    以上就是Linux 下tomcat错误分析的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    Linux系统运维及项目正式上线:点击学习

    上一篇:操作系统技巧总结 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• linux档案是什么样的• linux autofs是什么• linux中的上下文是什么• linux什么命令可以过滤控制字符• linux o和a什么文件
    1/1

    PHP中文网