JVM调优实战

2020-09-10  本文已影响0人  木木子丶

jvm可利用多大的内存空间

操作系统

jvm调优原则

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

什么是垃圾

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

如何找到这些垃圾

垃圾回收算法

  1. 标记哪些内存视为垃圾
  2. 直接清除被标记的垃圾

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

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

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

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

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

垃圾回收器

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

垃圾回收器选择

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

 -XX:+UseParallelGC -XX:+UseParallelOldGC

响应时间优先

-XX:+UseParNewGC -XX:+UseConcMarkSweepGC

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

-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
上一篇 下一篇

猜你喜欢

热点阅读