• jvm 内存参数设置


    概述

    java 内存溢出之后,我们需要根据错误信息分析一下内存溢出的具体原因,及时调整中间件的参数、

    查看 jvm 内存分配

    linux 下可以通过 jmap -heap【pid】命令查看 jvm 的内存分配
    例如:jmap -heap 1

     
     


    这个图可以看出
    MaxHeapSize = 1073741824 (1024.0MB) 最大堆内存 1G
    MaxNewSize = 536870912 (512.0MB) 最大新生代内存 512m
    OldSize = 536870912 (512.0MB) 老年代内存 512m
    NewRatio = 2 表示新生代:老年代=1:2
    SurvivorRatio = 8 表示 eden:Survivor=8:1

    参数调整

    jvm 的参数调整在 catalina.sh 文件中

     
     


    JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:NewRatio=2 -XX:SurvivorRatio=8"
    设置堆内存:-Xms1024m -Xmx1024m
    设置新生代内存:-XX:NewSize=256m -XX:MaxNewSize=256m
    设置新生代和老年代的比例:-XX:NewRatio=2
    设置伊甸园和 Survivor 的比例:-XX:SurvivorRatio=8
    设置栈内存:-Xss1m
    每个线程都会产生一个栈。在相同物理内存下,减小这个值能生成更多的线程。如果这个值太小会影响方法调用的深度
    设置最大持久代大内存:-XX:MaxPermSize=256m(jdk1.8 之后取消了持久代,改成了元空间)
    设置新生代代对象进入老年代的年龄:-XX:MaxTenuringThreshold=16
    设置新生代 gc 最大年龄。如果设置为 0 的话,则新生代对象直接进入老年代
    设置对象直接进入老年代的内存阈值:-XX:PretenureSizeThreshold=1024
    对象大小大于 1024 字节的直接在老年代分配对象

     来源:https://testerhome.com/articles/21258

  • 相关阅读:
    理解volatile与synchronized
    实现任意两个数的互换
    增删改查+部分前段内容
    Hibernate知识点小结汇总
    Spring知识点小结(一)
    JDBC相关
    Redis工具之Jedis
    Hibernate知识点小结(四)--JPA
    Hibernate知识点小结(三)-->一对多与多对多配置
    Hibernate知识点小结(二)
  • 原文地址:https://www.cnblogs.com/forestwolf/p/16194049.html
Copyright © 2020-2023  润新知