请教一个简单的技术问题,关于Linux下Tomcat内存占用问题.

  • v
    vonsy
    环境:
    8C/16G
    CentOS 7.5
    Tomcat 9.x
    JDK 8

    目标:
    不在Tomcat中部署任何应用, 但是想把内存占满.
    我在catalina.sh中配置了内存参数,但没效果.
    JAVA_OPTS="$JAVA_OPTS -server -XX:SruvivorRatio=8 -Xms10g -Xmx10g -Xmn2048m -Xss256k"

    使用以下命令查询,只占用了几百兆内存.
    top -p pid
    ps -aux|java
    cat /proc/pid/status

    怎么办?
  • d
    davidchiu
    xmn xms都配成16g试试
  • v
    vonsy
    不行,只占用了1.1, 1.2%



    2020-07-20_143542.png
  • a
    alvise
    JAVA_OPTS ,顾名思义,是用来设置JVM相关运行参数的变量。
    JVM:JAVA_OPTS="-server -Xms2048m -Xmx2048m -Xss512k"

    -server:一定要作为第一个参数,在多个CPU时性能佳
    -Xms:初始Heap大小,使用的最小内存,cpu性能高时此值应设的大一些
    -Xmx:java heap最大值,使用的最大内存
    上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小,建议均设为物理内存的一半。
    -XXermSize:设定内存的永久保存区域
    -XX:MaxPermSize:设定最大内存的永久保存区域
    -XX:MaxNewSize:
    -Xss 15120 这使得JBoss每增加一个线程(thread)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512k.
    +XX:AggressiveHeap 会使得 Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap。
    -Xss:每个线程的Stack大小
    -verbose:gc 现实垃圾收集信息
    -Xloggc:gc.log 指定垃圾收集日志文件
    -Xmn:young generation的heap大小,一般设置为Xmx的3、4分之一
    -XX:+UseParNewGC :缩短minor收集的时间
    -XX:+UseConcMarkSweepGC :缩短major收集的时间======================
    -XX PermSize:
    -XX:MaxPermSize: 这2个值设置到最大试试