美文网首页
JVM调优实战

JVM调优实战

作者: 木木子丶 | 来源:发表于2020-09-10 02:22 被阅读0次

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实战调优

    项目介绍 本项目是spring cloud zuul项目,程序内容就是做请求的签名加解密,然后对响应做加密。 项目...

  • JVM调优实战

    jvm可利用多大的内存空间 操作系统 32 位 : 2的32次方 = 4G - 操作系统一半空间= 2g--jvm...

  • JVM实战调优

    首先看自己能不能回答出这些问题。 垃圾回收算法 前六个是分代算法,G1是逻辑分代,物理不分代,ZGC是逻辑、物理都...

  • JVM 调优实战

    简书 许乐转载请注明原创出处,谢谢! 【案例】 最近我的同学遇到一个线上问题,线上机器的jvm进程频繁FullGC...

  • 谈谈性能调优思路

    声明:本文为学习总结篇,参考资料见文末,如有侵权请联系作者,调优实践总结篇可参考以往文章:JVM学习笔记与调优实战...

  • 3.JVM调优工具

    JVM调优工具 1、JVM调优工具-JDK工具 1.1 jps jps:Java Virtual Machine ...

  • JVM调优高频面试

    JVM调优目的 使用较小的内存占用来获得较高的吞吐量或者较低的延迟。 一、JVM内存调优 对JVM内存的系统级调优...

  • Spark(十八)JVM调优之原理概述以及降低cache操作的内

    一、调优背景 1、常规性能调优:分配资源、并行度。。。等 2、JVM调优(Java虚拟机):JVM相关的参数,通常...

  • 2019-10-12 jvm调优

    JVM调优总结

  • 18家大厂Java面试题整理了350道(分布式+微服务+高并发)

    一、性能调优系列 1.Tomcat性能调优 JVM参数调优:-Xms 表示JVM初始化堆的大小,-Xmx 表示J...

网友评论

      本文标题:JVM调优实战

      本文链接:https://www.haomeiwen.com/subject/meruektx.html