1. JVM内存结构

1.1 运行时数据区

程序计数器PC Register:JVM支持多线程同时执行,每一个线程都有自己的PC Register,线程正在执行的方法叫做当前方法,如果是java代码,PC Register里面存放的就是房钱正在执行的指令的地址,如果你是C代码,则为空。

  • Java虚拟机栈(Java Virtual Machine Stacks)是线程私有的,它的生命周期与线程相同。虚拟机栈描述的是Java方法执行的内存模型:每个方法在执行的同时都会创建一个栈帧,用于存储局部变量表、操作数栈、动态链接、方法出口灯信息。每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。
  • Java堆(Java Heap)是Java虚拟机所管理的内存中最大的一块。堆是被所有线程共享的一块内存区域,在虚拟机启动时创建。此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存。Java堆可以处于物理上不连续的内存空间中,只要逻辑上是连续的即可。
  • 方法区(Method Area):方法区域java堆一样,是各个线程共享的内存区域,它用于存储已被虚拟机加载的类信息、常亮、静态变量、即时编译器编译后的代码等数据。虽然Java虚拟机规范把方法区描述为堆的一个逻辑部分,但是它却有一个别名叫做Non-Heap(非堆),目的是与Java堆区分开来。
  • 运行时常量池(Runtime Constant Pool)是方法区的一部分。Class文件中除了有类的版本、字段、方法、接口等描述信息外,还有一项信息是常量池(Constant Pool Table),用于存放编译器生成的各种字面量和符号引用,这部分内容将在类加载后进入方法区的常量池中存放。
  • 本地方法栈(Native Method Stacks)与虚拟机栈所放回的作用是非常相似的,它们之间的区别不过是虚拟机栈为虚拟机执行的Java方法(也就是字节码)服务,而本地方法栈则为虚拟机使用到的Native方法服务。

1.2 JVM的内存结构

实例:

启用压缩类空间:

jstat -gc 13144

禁用压缩类空间:

jstat -gc 13523

codecache也是一样操作。

-xint

常用参数:

  • -Xms-Xmx
  • -XX:NewSize -XX:MaxNewSize
  • -XX:NewRatio -XX:SurvivorRatio
  • -XX:MetaspaceSize -XX:MaxMetaspaceSize
  • -XX:+UseCompressedClassPointers
  • -XX:CompressedClassSpaceSize
  • -XX:InitialCodeCacheSize
  • -XX:ReservedCodeCacheSize

2. 垃圾回收算法

2.1 如何确定垃圾

2.2 各类算法

对象分配:

  • 对象优先分配在Eden区。
  • 大对象直接进入老年代:-XX:PretenureSizeThreshold,该参数规定多大的对象会直接分配在老年代。
  • 长期存活对象进入老年代:
    -XX:MaxTenuringThreshold 晋升阈值
    -XX:+PrintTenuringDistribution 发生Young GC时候,打印存活对象的年龄的分布情况
    -XX:TargetSurivorRatio 设置Surivor区,Young区垃圾回收后存活对象的比例,假设该值设置为80%,意味着发生一次Young GC,Surivor区存活对象为80%,这时候需要计算这些80%存活对象的平均年龄,用平均年龄和晋升阈值之间取一个最小值,如果有对象年龄大于该最小值,也会将该对象晋升到老年代。

3. 垃圾收集器

3.1 三种类型垃圾收集器

  • 串行收集器Serial:Serial、Serial Old。单线程,适用于内存小的嵌入式设备。
  • 并行收集器Parallel:Paralel Scavenge、Parallel Old,吞吐量优先。
  • 并发收集器Concurrent:CMS、G1,停顿时间优先。

3.2 并行VS并发

  • 并行是指多条垃圾收紧线程并行工作,但此时用户线程仍然处于等待状态。适合科学计算、后台处理等弱交互场景。
  • 并发指用户线程与垃圾收集线程同时执行(但不一定是并行的,可能会交替执行),垃圾收集线程在执行的时候不会停顿用户程序的运行。适合对响应时间有要求的场景,比如Web。

3.3 停顿时间VS吞吐量

  • 停顿时间:垃圾收集器做垃圾回收中断应用执行的时间,-XX:MaxGCPauseMillis
  • 吞吐量:花在垃圾收集的时间和花在应用时间的占比。-XXGCTimeRatio=<n>,来及收集时间占:1/1+n。

3.4 如何评价一个垃圾回收器的好坏

3.5 三种类型垃圾收集器开启与停用

串行收集器:

并行收集器:

并发收集器:

3.6 垃圾收集器搭配

  • 有连线的是可以相互搭配使用。
  • JDK8推荐使用G1,性能比较好,在Yong区和Old区都可以使用。
  • 虚线表示CMS可能退化成SerialOld,空间担保分配失败。

如何选择垃圾收集器?

优先调整堆的大小,让JVM自己来选择;

  • 如果内存小于100M,使用串行收集器;
  • 如果是单核,并没有停顿时间的要求,串行或JVM自己选;
  • 如果允许停顿时间超过1秒,选择并行或JVM自己选;
  • 如果响应时间非常重要,并且不能超过1秒,使用并发收集器;

3.7 两种常用垃圾收集器

3.7.1 Parallel Collector

工作原理:当发现内存不够时,暂停应用程序,启动多个垃圾回收线程来回收垃圾,垃圾回收结束后,重新启动应用程序。

-XX:+UseParallelGC 手动开启,server模式默认开启;

-XX:ParallelGCThreads=<n> 开启多少个GC线程;

并行收集器的自适应特性(Parallel Collector Ergonomics),会自动调整堆得大小,来自适应调整满足我们设定的指标:

  • -XX:MaxGCPauseMills=<n> 最大停顿时间;
  • -XX:GCTimeRatio=<n> 吞吐量;
  • -Xmx<n> 堆的大小;
    优先满足停顿时间要求,然后满足吞吐量要求,如果两个都满足的话,它会减小堆得大小,来满足停顿时间的要求,直到这三个条件中有一个是满足不了的。自适应其实不是最优的,因为它需要动态调整堆得大小来满足这些条件。
    动态内存调整
    并行收集器在自适应的时候会动态调整内存;
  • -XX:YongGenerationSizeIncrement=<Y> Yong区动态调整每次增加的大小,默认20%;
  • -XX:TenuredGenerationSizeIncrement=<T> Old区动态调整每次增加的大小,默认20%;
  • -XX:AdaptiveSizeDecrementScaleFactor=<D> 动态减小时每次减小的大小,默认4%;
    在生产环境下很少使用自适应功能,主要通过手动调整。

3.7.2 CMS Collector

(1)CMS垃圾收集过程

由于篇幅限制原因,更多关于jvm知识点的学习思维导图以及上面垃圾收集的高清大图可以私信笔者“jvm”领取

java joptionpane调整大小_JAVA应用性能监控之JVM层GC调优相关推荐

  1. Java生产环境下性能监控与调优详解 第7章 JVM层GC调优

    第7章 JVM层GC调优 7-1 JVM的内存结构 7-2 常见的垃圾回收算法 7-3 垃圾收集器-1 7-4 垃圾收集器-2 7-5 GC日志格式详解 7-6 可视化工具分析GC日志 7-7 Par ...

  2. 48张图|手摸手教你性能监控、压测和调优

    本文主要内容 一.何为压力测试 1.1. 大白话解释 性能压测是什么:就是考察当前软件和硬件环境下,系统所能承受的最大负荷,并帮助找出系统的瓶颈所在. 性能压测的目的:为了系统在线上的处理能力和稳定性 ...

  3. java eden space_JVM GC调优一则–增大Eden Space提高性能

    缘起 线上有Tomcat升级到7.0.52版,然后有应用的JVM FullGC变频繁,在高峰期socket连接数,Cpu使用率都暴增. 思路 思路是Tomcat本身的代码应该是没有问题的,有问题的可能 ...

  4. 大数据技术之_19_Spark学习_07_Spark 性能调优 + 数据倾斜调优 + 运行资源调优 + 程序开发调优 + Shuffle 调优 + GC 调优 + Spark 企业应用案例

    大数据技术之_19_Spark学习_07 第1章 Spark 性能优化 1.1 调优基本原则 1.1.1 基本概念和原则 1.1.2 性能监控方式 1.1.3 调优要点 1.2 数据倾斜优化 1.2. ...

  5. Java 9 中的 GC 调优基础

    转载自   Java 9 中的 GC 调优基础 在经过了几次跳票之后,Java 9终于在原计划日期的整整一年之后发布了正式版.Java 9引入了很多新的特性,除了闪瞎眼的Module System和R ...

  6. 为什么Java有GC调优而没听说过有CLR的GC调优?

    前言 在很多的场合我都遇到过一些群友提这样的一些问题: 为什么Java有GC调优而CLR没有听说过有GC调优呢? 到底是Java的JVM GC比较强还是C#使用的.NET CLR的GC比较强呢? 其实 ...

  7. 软件性能测试分析与调优实践之路---性能测试系列-java gc调优

    性能测试中除了需要做好性能测试外,我们还需要做性能测试后的,性能调优,需要发现性能问题,也需要做性能调优,在做性能调优中,jvm的性能调优是经常遇到的一个. 随着jdk版本的迅速变化,jdk里面的GC ...

  8. java导出pdf_一张PDF了解JDK11 GC调优秘籍-附PDF下载

    简介 JDK11相比JDK10,添加了一个新的Source-File Mode,可以直接通过java来运行单个java源文件,而不需要进行编译.同时还提供了新的HTTP API,支持响应性stream ...

  9. java -jar 未响应_Java 方法性能监控和统计工具 MyPerf4J

    一个针对高并发.低延迟应用设计的高性能 Java 性能监控和统计工具. 特性 高性能: 单线程支持每秒 1000 万次 响应时间的记录,每次记录只花费 73 纳秒 无侵入: 采用 JavaAgent ...

最新文章

  1. html iso标准文档,HTML ISO-8859-1 参考手册
  2. [Z]图灵奖获得者Richard Karp讲述Berkeley CS的发展史
  3. 2.1 DNS服务介绍和安装
  4. Codeforces Round #377 (Div. 2) 732A B C D E F
  5. python装饰器setter_第7.27节 Python案例详解: @property装饰器定义属性访问方法getter、setter、deleter...
  6. Get data from file(xxx.png) failed!
  7. JS 动态创建元素、删除元素、替换元素、修改元素
  8. 电路维修(信息学奥赛一本通-T1448)
  9. Mybatis SQL片段
  10. 韩顺平HTML5教程www.gis520.com
  11. zabbix简介及部署
  12. flume hdfs sink 文件滚动策略
  13. c#中一般处理程序中使用session
  14. Android IOS WebRTC 音视频开发总结(六三)-- 2016国内IM云服务行业分析
  15. 陈纪修老师《数学分析》 第01章:集合与映射 笔记
  16. Java8实战(Java8 in Action)精华篇
  17. 基础知识 字节、KB、MB、GB 之间的换算关系
  18. 污水处理成本高怎么办?智能网关+云平台提供你完美解决方案
  19. HTTP协议详解你确定不看吗
  20. 华为云sql工程师评测答题[青铜+白银]

热门文章

  1. LINUX驱动注册过程失败处理不当引起的恶果
  2. 【移动通信】移动通信基础
  3. 6.Verilog的always语句使用
  4. C# 单精度转换双精度丢失的问题
  5. 基于element-ui实现table可配置化
  6. linux 常用快捷键
  7. Maven和Spring mvc下的页面的跳转与取值
  8. 关于NodeJS配置HTTPS服务、阿里云申请HTTPS证书
  9. windows 2008 server R2 版本概览
  10. CSP认证201512-3 画图[C++题解]:dfs、左下角建系、坐标反着读入