文档章节

JVM拾遗

echola
 echola
发布于 07/12 16:54
字数 954
阅读 31
收藏 0
点赞 0
评论 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
博文 22
码字总数 11751
作品 0
西安
程序员
noteless的博客导航页 所有文章的导航页面

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

noteless
06/29
0
0
Play框架拾遗之一:HTTP路由

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

奋斗到天明
2015/08/27
0
0
JDK、JRE、JVM三者间的关系

  JDK(Java Development Kit)是针对Java开发员的产品,是整个Java的核心,包括了Java运行环境JRE、Java工具和Java基础类库。Java Runtime Environment(JRE)是运行JAVA程序所必须的环境...

张德德
2014/02/28
0
0
JDK 1.7 基本概念和目录结构

参考资料: http://blog.csdn.net/kindazrael/article/details/7270673 http://docs.oracle.com/javase/7/docs/index.html JDK and JRE File Structure http://docs.oracle.com/javase/7/doc......

jack688
06/26
0
0
一句话讲清楚什么是JavaEE

Java技术不仅是一门编程语言而且是一个平台。同时Java语言是一门有着特定语法和风格的高级的面向对象的语言,Java平台是Java语言编写的特定应用程序运行的环境。Java平台有很多种,很多的Jav...

qq58edeba279279
06/26
0
0
My java——JVM(java 虚拟机)一

JVM是Java Virtual Machine(Java虚拟机)的缩写。一般我们在学习java中会用到很多缩写名称,如JRE、JDK、SDK、JAVA SE、JAVA EE、JAVA ME、JAVA FX、还有j2se、j2ee、javaee5,我勒个去!多...

tngou
2013/03/13
0
2
linux下的jdk环境变量配置

新安装的ubuntu不能以root用户登录,可以这样做 sudo passwd root //然后设置密码 su //输入密码登录 ubuntu 新建简单文本 touch hello.sh //新建文件 hello.sh vim hello.sh // 打开hello文...

苏云飞
2015/11/18
0
0
ThreadLocal in Java - Example Program and Tutorial

ThreadLocal in Java is another way to achieve thread-safety apart from writing immutable classes. If you have been writing multi-threaded or concurrent code in Java then you mus......

perfectspr
2014/12/10
0
0
JVM基础:深入学习JVM堆与JVM栈

以前堆是干啥栈是干啥都知道,就是没连在一起想想。感觉讲的不错的一篇儿~~JVM栈解决程序的运行问题,即程序如何执行,或者说如何处理数据;JVM堆解决的是数据存储的问题,即数据怎么放、放在...

李星
2014/06/04
0
0
【目录导航】JAVA零基础进阶之路

【JAVA零基础入门系列】(已完结)导航目录 Day1 开发环境搭建 Day2 Java集成开发环境IDEA Day3 Java基本数据类型 Day4 变量与常量 Day5 Java中的运算符 Day6 Java字符串 Day7 Java输入与输出...

MFrank
06/21
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

FOMO游戏代码解析

源代码在此处

怎当她临去时秋波那一转
5分钟前
0
0
EOS智能合约与DApp开发入门

EOS的是Block.One主导研发的一个区块链底层公链系统,它专门为支撑商业去中心化 应用(Decentralized Application)而设计,其代码开源。 比特币被称为区块链1.0,因为它开辟了数字加密货币的...

笔阁
18分钟前
0
0
编译cjson到dll

https://blog.csdn.net/mengzhisuoliu/article/details/52203724 编译完成后 是纯lua实现的json decode 的10倍以上...

梦想游戏人
27分钟前
0
0
JS基础- Date 对象

Date 对象 Date 对象用于处理日期和时间。 创建 Date 对象的语法: var myDate=new Date() 注释:Date 对象会自动把当前日期和时间保存为其初始值。 Date 对象属性 属性 描述 constructor 返...

ZHAO_JH
30分钟前
0
0
Python数据分析numpy(1)

Python开源的科学计算基础库 1.表示N维数组对象ndarray 2.线性代数、傅里叶变换、随机数生成 3.广播函数,整合c++、c 一.数据的维度 1.数据 2.数据维度 3.一维数据 (1)特点 (2)Python中的...

十年磨一剑3344
32分钟前
0
0
csv导入Hive脚本

from pyspark.sql import HiveContexthivec = HiveContext(sc) # 创建一个hivecontext对象用于写执行SQL,sc为sparkcontext# 拼接一个字段类型字符串str_s = 'label String,'...

gulf
34分钟前
0
0
TensorFlow 隐含层 拟合 异或运算

a⊕b = (¬a ∧ b) ∨ (a ∧¬b) 数据 X = [[0, 0], [0, 1], [1, 0], [1, 1]]Y = [[0], [1], [1], [0]] 单层网络只能拟合线性问题,由于异或是非线性问题,需要使用多层网络 输入和输出 [[...

阿豪boy
49分钟前
0
0
SVN 教程

http://www.runoob.com/svn/svn-tutorial.html 记一次 svn 管理的项目迁移工作 之前A服务器上的项目版本管理工具是用的SVN,后来,之前管理linux服务器的员工离职了,这管理服务器的工作也就...

yeahlife
49分钟前
0
0
在Python中,不用while和for循环遍历列表

a = [1, 2, 3, 8, 9]def printlist(l, index): if index == len(l): return else: print(l[index]) printlist(l, index + 1)printlist(a,......

丁典
50分钟前
0
0
Kubernetes使用中发现的错误及解决

运行 kubectl dashboard 时报错: Error validating service: Error getting service kubernetes-dashboard: services "kubernetes-dashboard" not found 排查 kubectl get po --all-names......

哎码
56分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部