文档章节

JVM拾遗

echola
 echola
发布于 07/12 16:54
字数 954
阅读 33
收藏 0

image

JVM内部结构

程序计数器

  • 每个线程有一个
  • 存储当前线程正在执行的方法在JVM中的指令地址。如果是本地方法,则是未指定值。

JVM虚拟机栈

  • 每个线程在创建时会创建一个。
  • 保存一个个的栈帧,对应一次次的方法调用。
  • 栈帧存放局部变量表、操作数栈、动态链接等。

方法区

  • 所有线程共享,存储元(Meta)数据,包括常量池、类结构信息等

本地方法栈

  • 每个线程都会创建
  • 调用本地方法

堆内结构

  • 新生代:大部分对象创建和销毁的区域
    • Eden
    • from (Survivor)
    • to (Survivor):将Eden活下来的对象和from区域的对象拷贝到to区域
  • 老年代:放置长生命周期的对象,通常是从Survivor区域拷贝过来的对象,还有大对象。
  • 永久代:元数据、常量池、Inter字符串缓存。
参数
  • 最大堆体积
-Xmx value
  • 初始的最小堆体积
-Xms value
  • 老年代和新生代的比例
-XX:NewRatio=value (默认为3,老年代是新生代的3倍)
-XX:NewSize=value (直接定义新生代的大小) 

GC调优的主要方面

  • 内存占用过高
  • 吞吐量
  • 延时

CPU占用过高? 内存占用100%

  1. 查看Java PID
jps
  1. 输出堆栈信息到log文件
jstack [pid] >xxx.log
  1. 查看pid进程占用CPU最高的线程,使用ProcessExplorer工具
  2. 将线程ID转为16进制,去log文件里面查找。

查看堆内,堆外的使用情况

JDK垃圾回收

GC的类型
  • Serial GC :串行模式,"Stop the world",复制算法,用于新生代,响应速度优先,适用于单CPU模式下的Client模式。
  • ParNew GC:Serial GC的多线程版本,最常见的应用是配合老年代的CMS GC,对应参数
-XX:+UseConcMarkSweepGC -XX:+UseParNewGC
  • CMS(Concurrent Mark Sweep) GC,给予标记-清除算法,存在碎片化问题,会导致Full GC
  • Parrellel GC,吞吐量优先,老年代和新生代GC同时进行。
  • G1 GC兼顾吞吐量和停顿时间的GC,JDK9以后的默认GC,标记-整理算法。Java堆非常大的时候非常有优势。
GC主要收集哪里的内存?
  • 实例对象,在堆上面
  • 方法区的元数据信息
GC算法
  • 复制:直接按照顺序复制,避免内存碎片,但是会有空间浪费
  • 标记-清除:标记出要回收的对象,然后清除。标记、清除效率有限,产生内存碎片。不合适特别大的堆,否则,FullGC时间太长。
  • 标记-整理:类似标记清除,在清除过程中,会移动对象,避免内存碎片化。
GC的过程

new 对象-->Eden区达到阈值-->GC-->活着的对象被移植到Survivor,Eden变空-->new 对象-->Eden区达到阈值-->GC-->一个Survivor区域变为to区域,Eden区域的存活对象和from区域的对象被复制到to区域,存活年龄计数+1 -->超过阈值-->GC,复制到老年代。

日志打印GC的过程
-XX:+PrintGC 输出GC日志
-XX:+PrintGCDetails 输出GC的详细日志
-XX:+PrintGCTimeStamps 输出GC的时间戳(以基准时间的形式)
-XX:+PrintGCDateStamps 输出GC的时间戳(以日期的形式,如 2013-05-04T21:53:59.234+0800)
-XX:+PrintHeapAtGC 在进行GC的前后打印出堆的信息
-Xloggc:../logs/gc.log 日志文件的输出路径

© 著作权归作者所有

共有 人打赏支持
echola
粉丝 13
博文 23
码字总数 12268
作品 0
西安
程序员
私信 提问
noteless的博客导航页 所有文章的导航页面

导航 《spring springmvc mybatis maven 项目整合示例系列-导航页》 《JAVA 基础知识点拾遗系列 JAVA学习 -1层 导航页》 《计算机软硬件发展系列个人理解与总结-导航页》...

noteless
06/29
0
0
Java拾遗:008 - 对象克隆与浅拷贝、深拷贝

对象克隆 Object类中有一个方法叫,完整代码 首先它是一个Native方法,而且是受保护的(),抛出一个异常(JDK1.8)。 通常程序员自己定义的类不能直接调用方法,如果要在外部调用,需要重写...

一别丶经年
08/04
0
0
Java拾遗:001 - 重写 equals 和 hashCode 方法

重写equals方法 在Java中Object类是一个具体类,但它设计的主要目的是为了扩展,所以它的所有非final方法,都被设计成可覆盖(override)的。但任何一个子类在覆盖这些方法时都应遵守一些通用...

一别丶经年
08/02
0
0
Java拾遗:005 - Java的四种引用类型

简介 Java中为了让程序员可以自己控制对象生命周期,提供了四种引用方式,都继承自类,它们分别是:强引用、软引用、弱引用、虚引用。 强引用(FinalReference / Finalizer) 在Java中像这种...

一别丶经年
08/03
0
0
Play框架拾遗之一:HTTP路由

这系列五篇文章,是我在涮www.playframework.cn的读摘,记录了一下重要能用得着,但是又不太熟悉的内容,根据层次划分了五章。 1、路由语法 Play 支持HTTP中规定的GET/POST/PUT/DELETE/HEAD五...

奋斗到天明
2015/08/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

CAS和AQS

CAS(Compare And Swap) 什么是CAS CAS(Compare And Swap),即比较并交换。是解决多线程并行情况下使用锁造成性能损耗的一种机制。 CAS是一种系统原语,原语属于操作系统用语范畴,是由若干条...

狼王黄师傅
14分钟前
1
0
Python利用pandas处理Excel数据的应用

Python利用pandas处理Excel数据的应用 最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做自动化...

上官夏洛特
28分钟前
1
0
100:代码管理平台svn

1:代码管理平台:代码版本管理工具,工作中用于代码更新,代码发布统计,代码版本控制;(频繁更新代码的版本记录),方便查阅历史变更,协同开发及合并; 版本管理工具发展: cvs(编码兼容不太好)...

芬野de博客
28分钟前
0
0
Linux学习-1101(rsync下、log、screen)

10.32/10.33 rsync通过服务同步 10.34 linux系统日志 10.35 screen工具 一、 rsync通过服务同步 rsync 通过服务的方式同步,首先需要开启一个服务。它是C/S架构,开启rsync服务,默认端口是8...

wxy丶
35分钟前
1
0
使用jpmml-sparkml-executable生成PMML模型文件

加载依赖的jar包通过./spark-shell --jars ./jpmml-sparkml-executable-1.2.13.jar 启动spark import org.apache.spark.ml.classification.LogisticRegressionimport org.apache.spark.m......

KYO4321
38分钟前
1
1

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部