自学提高:JVM点滴

简介:

写在前面

   这年头就是得不断地学习. 学什么东西就看需要了. 不学习很难进步. 同时别人也会超过你. 东西都是网上有的。图片也好,文字也好。基本都可以在网上找到。

 

JAVA运行原理

4de3796435fa480ea08a4ab3684b485f69c811da

JVM包括字节码解释程序,执行器,方法区,堆,VM栈,本地方法栈,Program Counter计数器。

b7218a46485d4c73568a77fb5da7b3a3d87ec1ec

f7634950836e5ee77cd66dccaefcdd6cd6e83c05

垃圾回收算法

a22230c447b6a51e7b675c0e7690c78c9e7ed5ed

GC主要分二类,新生代GC,老年代GC;

新生代GC包括:串行GC、并行GC、并行回收GC

老年代GC包括:串行GC、并行GC、CMS

G1比较特殊,同时支持新生代和老年代

GC选择:

GC在选择上,主要关注两点,吞吐量优先和暂停时间优先,

对于吞吐量优先的采用server默认的并行GC(Parallel GC)方式(上图蓝色区域),

对于暂停时间优先的选用并发GC(CMS)方式(上图黄色区域),常用场景:互联网、电商类

常用GC开启方式

暂停时间优先: 并行GC + CMS

开启方式[ -XX:+UseConcMarkSweepGC -XX:+UseParNewGC ]

吞吐量优先: 并行回收GC + 并行GC

开启方式 [ -XX:+UseParallelOldGC ] ,此GC也时server模式默认的配置

G1: [ -XX:+UseG1GC ]

适用于服务器端、大内存、多CPU情景的垃圾收集器;

G1的目标是在维持高效率回收的同时,提供软实时中断特性

常用场景:hadoop、elasticsearch

CMS和G1区别

Cms 堆 -> 年轻代老年代

G1 堆 -> 多个区 -> 每个区里(年轻代老年代)

Cms 标记清理算法

G1 压缩复制算法,不产生碎片

G1 时间停顿可设置,相关参数[ -XX:MaxGCPauseMillis=100 -XX:GCPauseIntervalMillis=200 ]

 4f5e53b74b8e726adb537bcca42957cd06fb46e3

需要注意的是,JDK8中已经用Metaspace(元数据区)完全替代了永久代(即方法区)

而且元数据区内存不在JVM中,而是使用的本地内存,默认情况下受操作系统内存限制。

调整元数据区内存大小的参数 -XX:MetaspaceSize -XX:MaxMetaspaceSize

目录
相关文章
|
4月前
|
存储 安全 Java
JVM面试
JVM面试
28 1
|
5月前
|
算法 前端开发 Java
JVM面试必备
JVM面试必备
|
6月前
|
存储 监控 安全
21个 JVM 技术点详解(附面试解答)
以上V哥给大家详细介绍了 JVM 中涉及的21个点,全网还没有针对 JVM 这样来梳理的内容,希望对你深入了解 JVM 有一定帮助,另,V 哥给大家推荐一本《深入 JVM 虚拟机》的书籍,可以作为工具书使用,高阶的 Java 程序员几乎人手一本。今天的分享就到这里,任何疑问欢迎与 V 哥一起交流,畅谈 Java 人生。
|
6月前
|
存储 监控 数据可视化
技术小白应该知道的关于JVM的一些事
技术小白应该知道的关于JVM的一些事
|
Arthas 监控 算法
JVM第一讲:JVM相关知识体系详解+面试(P6熟练 P7精通)
JVM第一讲:JVM相关知识体系详解+面试(P6熟练 P7精通)
284 2
|
算法 Java 程序员
JVM面试专题:面试中JVM常问的问题你都知道吗?
JVM面试专题:面试中JVM常问的问题你都知道吗?
162 1
JVM面试专题:面试中JVM常问的问题你都知道吗?
|
存储 算法 安全
JVM从入门到入土之详解G1垃圾回收器
前言 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/bin392328206/six-finger
549 0
|
Arthas 缓存 人工智能
JVM面试都问些啥?面试还不懂JVM性能调优,看这一篇文章就够了
昨晚,我在路口等车的时候,听到几个人在那讨论问题: “之前我用 jprofiler 监控 jvm 里的对象,当老年代满了,我手动触发一次 fgc,发现只能回收一半,再触发一次,就完全回收,这种情况正常吗?” “是不是你的应用正在执行过程中啊?” “可以考虑下 finalize,弱引用缓存等。” “那你们怎么确定 CPU 线程上下文切换消耗资源的?你们咋改进的?”
|
Web App开发 监控 Oracle
面试必问JVM篇
面试必问篇
224 0
|
缓存 监控 算法
50.【面试宝典】面试宝典-JVM垃圾回收
【面试宝典】面试宝典-JVM垃圾回收
50.【面试宝典】面试宝典-JVM垃圾回收