JVM调优实战

jvm可利用多大的内存空间

操作系统

  • 32 位 : 2的32次方 = 4G - 操作系统一半空间= 2g--jvm
  • 64 位 : 2的64次方 = 16384PB -操作系统2G = 剩余空间

jvm调优原则

  • gc时间足够小(堆内存设置小一些)
  • gc次数足够少(堆内存设置大一些)

一般做调优要选取balance(平衡)的一种状态

什么是垃圾

没有被引用的对象就是垃圾

如何找到这些垃圾

  • 引用计数法: 在程序计数器当一个对象的引用值变为0的时候,进行标记,无法解决循环引用问题
  • 跟可达算法: 每个引用对象作为根节点向下寻找,解决循环引用问题

垃圾回收算法

  • Mark-sweep 标记清除算法
  1. 标记哪些内存视为垃圾
  2. 直接清除被标记的垃圾

优点: 性能快
缺点: 会产生内存脆片

  • Copying 拷贝算法
  1. 将内存空间分为两部分,分别存储可用空间和垃圾空间
  2. 清除垃圾对象后直接将存活对象移到可用空间里

优点: 没有内存碎片
缺点: 存在内存空间浪费

  • Mark-compark 标记拷贝压缩算法
  1. 标记哪些内存区域是垃圾
  2. 将存货对象拷贝到另一端(连续空间)
  3. 清除剩下的垃圾

优点: 没有内存碎片,使用的是连续空间
缺点: 性能较慢,

垃圾回收器

  • 串行化垃圾回收器
Serial(年轻代垃圾回收) + serial old : 支持单核心 cpu 垃圾回收
  • 并行垃圾回收期
Parnew (年轻代垃圾回收): 是 Parallel scavenge 增强型垃圾回收器,主要是为
了更好和 cms 垃圾回收器相结合而开发的垃圾回收器。
Cms(老年代垃圾回收):垃圾回收时候和线程执行交叉进行。STW 耗时更少。
Parallel scavenge(年轻代垃圾回收):并行垃圾回收器,特点:stop the world gc
暂停时间稍微长
Parallel old(老年代垃圾回收): 并行垃圾回收器
  • G1
    同时支持老年代和新生代垃圾回收器

垃圾回收器选择

  • Ps + Po

ps + po 都采用并行方式进行垃圾回收,适用于吞吐量优先的方式,jdk8 默认采用该方式

 -XX:+UseParallelGC -XX:+UseParallelOldGC
  • Paranew + cms

响应时间优先

-XX:+UseParNewGC -XX:+UseConcMarkSweepGC
  • G1

同时支持新生代和老年代回收器

-XX:+UseG1GC

其他调优参数

nohup java -Xmx3550m -Xms3550m -Xmn2g -Xss256k -jar 
jshop-web-1.0-SNAPSHOT.jar --spring.config.addition-location=application.yaml > 
log.log 2>&1 & -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC 
-Xloggc:gc.log

-Xmx :最大堆内存,一般情况下内存设置不能超过80%,一般设置为50%-80%

-Xms : 初始化堆内存,这个内存一般情况下都必须和Xmx设置为一致大小

-Xmn : 设置年轻代大小

-Xss : 每一个线程堆栈大小,这个大小可以限制线程数量,默认为1M

gc日志

-XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC 
-Xloggc:gc.log

内存分带模型

年轻代

  1. Eden : 对象诞生的地方
  2. S1 :
  3. S2 : S1和S2在每次回收时进行标记增加年龄,互相拷贝到对方的内存中

老年代

  1. Old Generation : 默认年轻代15岁后进入老年代(可配置)

持久代

  1. Perm/Meta

你可能感兴趣的:(JVM调优实战)