• JVM内存模型


    JVM整体结构及内存模型

    0

    蓝色区域是每个线程都有的,独有不共享

    JVM内存参数设置

    0

    Spring Boot程序的JVM参数设置格式(Tomcat启动直接加载bin目录下catalina.sh文件里):

    java -Xms2048M -Xmx2048M -Xmn1024M -Xss512K -XX:MetaspaceSize=256M -XX:MaxMetaspaceSize=256M -jar microservice-eureka-server.jar
    
    • 1

    -Xss:每个线程的栈大小,-Xss设置越小count值越小,说明一个线程栈里能分配的栈帧就越少,但是对JVM整体来说能开启的线程数会更多

    -Xms:设置堆的初始可用大小,默认物理内存的1/64

    -Xmx:设置堆的最大可用大小,默认物理内存的1/4

    -Xmn:新生代大小

    -XX:NewRatio:默认2表示新生代占年老代的1/2,占整个堆内存的1/3。

    -XX:SurvivorRatio:默认8表示一个survivor区占用1/8的Eden内存,即1/10的新生代内存。

    关于元空间的JVM参数有两个:-XX:MetaspaceSize=N和 -XX:MaxMetaspaceSize=N

    -XX:MaxMetaspaceSize: 设置元空间最大值, 默认是-1, 即不限制, 或者说只受限于本地内存大小。

    -XX:MetaspaceSize: 指定元空间触发full gc的初始阈值(元空间无固定初始大小), 以字节为单位,默认是21M左右,达到该值就会触发full gc进行类型卸载, 同时收集器会对该值进行调整: 如果释放了大量的空间, 就适当降低该值; 如果释放了很少的空间, 那么在不超过-XX:MaxMetaspaceSize(如果设置了的话) 的情况下, 适当提高该值。方法区最好设置值,不然会动态扩容缩小,频繁gc导致启动程序缓慢

    高该值。方法区最好设置值,不然会动态扩容缩小,频繁gc导致启动程序缓慢

    由于调整元空间的大小需要Full GC,这是非常昂贵的操作,如果应用在启动的时候发生大量Full GC,通常都是由于永久代或元空间发生了大小调整,基于这种情况,一般建议在JVM参数中将MetaspaceSize和MaxMetaspaceSize设置成一样的值,并设置得比初始值要大,对于8G物理内存的机器来说,一般我会将这两个值都设置为256M。

  • 相关阅读:
    面试题 01.09.字符串轮转
    .NET实现解析字符串表达式
    RabbitMQ简介
    java图像化界面GUI(swing)学习讲解
    【大数据】Kafka 入门指南
    【Java实验五】继承与多态
    Linux中getopt函数、optind等变量使用详解
    Spring Cloud Gateway 网关实现白名单功能
    OLED透明屏导航:驾驶安全的未来趋势
    ros2与windows入门教程-修改域Domain_ID
  • 原文地址:https://blog.csdn.net/xwj1992930/article/details/133271064