内存分布
1 程序计数器 : 记录JVM 运行指令的位置,线程独立
2 栈 线程独立,主要是局部变量、操作数
3 堆 线程共享
4 方法区 : 线程共享:类信息、常量、静态常量, 就是编译后的代码等数据
内存回收方法:
标记-清除算法(存活对象、可回收、未使用), 最基本的算法,内存碎片太多
复制算法( 保留 两份,一份使用,一份冗余):新生代 基本使用此方法; IBM 研究表明 新生代内存 中98% 的对象都会朝生夕死 ,所以Eden 区 : survivor 区 为8:1;
标记整理算法: 先标记,然后将存活对象 移动到一端,然后直接清理当前端
垃圾收集器
新生代收集器
Serial 收集器: 单线程收集, 收集时 Stop the world ,主要用在 Client 模式的应用中 ()
ParNew 收集器: 多线程收集,其余与Serial 类似,也是stop the world; Server 端 用的比较多,主要是 只有他能与 CMS 配合工作
Parallel scavenge 收集器(吞吐量优先): 也是并行使用copy 算法进行收集,但是其不stop the world;而是可以保留 部分用户吞吐量
老年代收集器
Serial old 收集器:标记 整理, 也是stop the wold ,主要用于client 模式,效率高
Parallel old 收集器: Parallel scavenge 的老年代版本,使用标记-整理算法
CMS 收集器(Concurrent Mark Sweep): 最短回收停顿时间; 标记-清除算法
G1 收集器:标记-整理或者 复制算法;
问题定位:
jps -l 查看进程以及对应的 启动jar 包
jps -v 查看jvm 启动参数
jstat -gc 27280 2000 10
jstat -gcutil 27280 2000 10
jstat -options 可以查看所有的选项
jinfo 查看或者调整虚拟机运行参数
jinfo -flags 27280 查看所有参数
jinfo -flag ConcGCThreads 23728 查看具体某个参数
jmap 主要用于生成堆快照
jmap -dump:live,format=b,file=/tmp/23728_2.prof 23728
(jhat 23728_2.prof 可以解析此dump 文件, 生成一个服务器,使用localhost:7000 查看对应数据, 关注 Show heap histogram )
jstack -l 23728 查看 线程堆栈