zoukankan      html  css  js  c++  java
  • Tomcat与内存泄露

    一、Tomcat的JVM提示内存溢出

    查看%TOMCAT_HOME%logs文件夹下,日志文件是否有内存溢出错误

    二、修改Tomcat的JVM

    1、错误提示:java.lang.OutOfMemoryError: Java heap space

    Tomcat默认可以使用的内存为128MB,在较大型的应用项目中,这点内存是不够的,有可能导致系统无法运行。常见的问题是报Tomcat内存溢出错误,Out of Memory(系统内存不足)的异常,从而导致客户端显示500错误,一般调整Tomcat的使用内存即可解决此问题。

    Windows环境下修改“%TOMCAT_HOME%incatalina.bat”文件,在文件开头增加如下设置:set JAVA_OPTS=-Xms256m -Xmx512m
    Linux环境下修改“%TOMCAT_HOME%incatalina.sh”文件,在文件开头增加如下设置:JAVA_OPTS=’-Xms256m -Xmx512m’

    其中,-Xms设置初始化内存大小,-Xmx设置可以使用的最大内存。

    2、错误提示:java.lang.OutOfMemoryError: PermGen space

    原因:
    PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,这块内存主要是被JVM存
    放Class和Meta信息的,Class在被Loader时就会被放到PermGen space中,它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的应用中有很CLASS的话,就很可能出现PermGen space错误,这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar, 其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。
    解决方法:

    Windows在catalina.bat的第一行增加:
    set JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m -
    XX:MaxPermSize=256m
    Linux在catalina.sh的第一行增加:
    JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m -
    XX:MaxPermSize=256m

    3、JVM设置

    堆的尺寸
    -Xmssize in bytes
        设定Java堆的初始尺寸,缺省尺寸是2097152 (2MB)。这个值必须是1024个字节(1KB)的倍数,且比它大。(-server选项把缺省尺寸增加到32M。)
    -Xmnsize in bytes
        为Eden对象设定初始Java堆的大小,缺省值为640K。(-server选项把缺省尺寸增加到2M。)
    -Xmxsize in bytes
        设定Java堆的最大尺寸,缺省值为64M,(-server选项把缺省尺寸增加到128M。) 最大的堆尺寸达到将近2GB(2048MB)。

    请注意:很多垃圾收集器的选项依赖于堆大小的设定。请在微调垃圾收集器使用内存空间的方式之前,确认是否已经正确设定了堆的尺寸。

    垃圾收集:内存的使用
    -XX:MinHeapFreeRatio=percentage as a whole number
        修改垃圾回收之后堆中可用内存的最小百分比,缺省值是40。如果垃圾回收后至少还有40%的堆内存没有被释放,则系统将增加堆的尺寸。
    -XX:MaxHeapFreeRatio=percentage as a whole number
        改变垃圾回收之后和堆内存缩小之前可用堆内存的最大百分比,缺省值为70。这意味着如果在垃圾回收之后还有大于70%的堆内存,则系统就会减少堆的尺寸。
    -XX:NewSize=size in bytes
        为已分配内存的对象中的Eden代设置缺省的内存尺寸。它的缺省值是640K。(-server选项把缺省尺寸增加到2M。)
    -XX:MaxNewSize=size in bytes
        允许您改变初期对象空间的上限,新建对象所需的内存就是从这个空间中分配来的,这个选项的缺省值是640K。(-server选项把缺省尺寸增加到2M。)
    -XX:NewRatio=value
        改变新旧空间的尺寸比例,这个比例的缺省值是8,意思是新空间的尺寸是旧空间的1/8。
    -XX:SurvivorRatio=number
        改变Eden对象空间和残存空间的尺寸比例,这个比例的缺省值是10,意思是Eden对象空间的尺寸比残存空间大survivorRatio+2倍。
    -XX:TargetSurvivorRatio=percentage
        设定您所期望的空间提取后被使用的残存空间的百分比,缺省值是50。
    -XX:MaxPermSize=size in MB
        长久代(permanent generation)的尺寸,缺省值为32(32MB)。

    三、查看Tomcat的JVM内存

    1. Tomcat6中没有设置任何默认用户,因而需要手动往Tomcat6的conf文件夹下的tomcat-users.xml文件中添加用户。

        如:<role rolename="manager"/>
              <user username="tomcat" password="tomcat" roles="manager"/>

        注:添加完需要重启Tomcat6。

    2. 访问http://localhost:8080/manager/status,输入上面添加的用户名和密码。

    3. 然后在如下面的JVM下可以看到内存的使用情况。

    JVM

        Free memory: 2.50 MB Total memory: 15.53 MB Max memory: 63.56 MB

    四、Tomcat连接数设置

    在tomcat配置文件server.xml中的<Connector ... />配置中,和连接数相关的参数有:
    minProcessors:最小空闲连接线程数,用于提高系统处理性能,默认值为10
    maxProcessors:最大连接线程数,即:并发处理的最大请求数,默认值为75
    maxThreads最大并发线程数,即同时处理的任务个数,默认值是200
    acceptCount:允许的最大连接数,应大于等于maxProcessors,默认值为100
    enableLookups:是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
    connectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
    其中和最大连接数相关的参数为maxProcessors和acceptCount。如果要加大并发连接数,应同时加大这两个参数。
    web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。Unix中如何设置这些参数,请参阅Unix常用监控和管理命令

    备注:

    #tomcat内存配置
    JAVA_OPTS="-server -Xms512m -Xmx1024m -Xss1025k -XX:PermSize=128M -XX:MaxNewSize=512m -XX:MaxPermSize=256m -Djava.awt.headless=true -Djava.library.path=$JAVA_HOME/jre/lib/amd64"

    <Connector port="8888" protocol="HTTP/1.1"
                   maxThreads="500" minSpareThreads="50" maxSpareThreads="100" enableLookups="false" acceptCount="2000"
                   connectionTimeout="20000"
                   redirectPort="8443" />

  • 相关阅读:
    教程:在 Visual Studio 中开始使用 Flask Web 框架
    教程:Visual Studio 中的 Django Web 框架入门
    vs2017下发现解决python运行出现‘No module named "XXX""的解决办法
    《sqlite权威指南》读书笔记 (一)
    SQL Server手工插入标识列
    hdu 3729 I'm Telling the Truth 二分图匹配
    HDU 3065 AC自动机 裸题
    hdu 3720 Arranging Your Team 枚举
    virtualbox 虚拟3台虚拟机搭建hadoop集群
    sqlserver 数据行统计,秒查语句
  • 原文地址:https://www.cnblogs.com/yangxia-test/p/3611385.html
Copyright © 2011-2022 走看看