• 自学提高:JVM点滴


    写在前面

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

    JAVA运行原理

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

     

    垃圾回收算法

     

    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 ]

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

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

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

  • 相关阅读:
    CSLA服务端如何使用多线程的解决方案
    一片马蜂窝文章
    VB.NET和C#之间的语法不同比较
    [软件推荐]jQuery,JavaScript,HTML,CSS,PHP,MySQL,正则表达式 CHM帮助手册
    使用jQuery.Validate进行客户端验证
    知道AutoHotKey
    数据库设计问题
    [书籍推荐]为了自己的钱包,为了自己的时间——分享一下自己的淘书经验
    策略模式4
    SQLiteHelperSQLite帮助类
  • 原文地址:https://www.cnblogs.com/mikelij/p/8414820.html
Copyright © 2020-2023  润新知