java 内存分析和调优

一个应用在运行,如何分析该应用使用了多少内存?内存里面都有哪些内容?加载了哪些类? 应用在启动的过程中往内存中加载了哪些内容?应用在运行的过程中,如何在内存中查看动态加载的类?
内存有哪几部分组成?
内存内部如何转移?
应用启动过程加载了类

1、在启动语句中加上以下参数: -verbose:class -verbose:gc -verbose:jni
会打印GC,和 FGC过程和频率。
#启动后打印的加载的类:
GC进行垃圾回收。

2、加载的class数目
[root@localhost script]# jstat -class 14054 4s
Loaded Bytes Unloaded Bytes Time
1918 3760.9 0 0.0 0.61
1918 3760.9 0 0.0 0.61

3、jvm内存变化
[root@localhost ~]# jstat -gcutil 14054 4s
S0 S1 E O P YGC YGCT FGC FGCT GCT
0.00 83.33 40.53 20.33 2.73 11 0.028 0 0.000 0.028
0.00 83.33 40.53 20.33 2.73 11 0.028 0 0.000 0.028
0.00 83.33 40.53 20.33 2.73 11 0.028 0 0.000 0.028
0.00 83.33 40.53 20.33 2.73 11 0.028 0 0.000 0.028

3、查看内存分配情况
[root@localhost script]# jmap -heap 14054
Attaching to process ID 14054, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 20.45-b01
using thread-local object allocation.
Parallel GC with 13 thread(s)
Heap Configuration:
MinHeapFreeRatio = 40
MaxHeapFreeRatio = 70
MaxHeapSize = 33554432 (32.0MB)
NewSize = 1310720 (1.25MB)
MaxNewSize = 17592186044415 MB
OldSize = 5439488 (5.1875MB)
NewRatio = 2
SurvivorRatio = 8
PermSize = 536870912 (512.0MB)
MaxPermSize = 1073741824 (1024.0MB)
Heap Usage:
PS Young Generation
Eden Space:
capacity = 7208960 (6.875MB)
used = 1409920 (1.3446044921875MB)
free = 5799040 (5.5303955078125MB)
19.557883522727273% used
From Space:
capacity = 1245184 (1.1875MB)
used = 163840 (0.15625MB)
free = 1081344 (1.03125MB)
13.157894736842104% used
To Space:
capacity = 1441792 (1.375MB)
used = 0 (0.0MB)
free = 1441792 (1.375MB)
0.0% used
PS Old Generation
capacity = 11206656 (10.6875MB)
used = 2310816 (2.203765869140625MB)
free = 8895840 (8.483734130859375MB)
20.62003152412281% used
PS Perm Generation
capacity = 536870912 (512.0MB)
used = 14677496 (13.997550964355469MB)
free = 522193416 (498.00244903564453MB)
2.7338966727256775% used
[root@localhost script]#

4、 查看加载的class:    jmap -histo -F 31343 | more

5、分代垃圾回收过程:
如上图所示,为Java堆中的各代分布。



1. Young(年轻代)
年轻代分三个区。一个Eden区,两个Survivor区。大部分对象在Eden区中生成。当Eden区满时,还存活的对象将被复制到Survivor区(两个中的一个),当这个Survivor区满时,此区的存活对象将被复制到另外一个Survivor区,当这个Survivor去也满了的时候,从第一个Survivor区复制过来的并且此时还存活的对象,将被复制“年老区(Tenured)”。需要注意,Survivor的两个区是对称的,没先后关系,所以同一个区中可能同时存在从Eden复制过来 对象,和从前一个Survivor复制过来的对象,而复制到年老区的只有从第一个Survivor去过来的对象。而且,Survivor区总有一个是空的。

2. Tenured(年老代)
年老代存放从年轻代存活的对象。一般来说年老代存放的都是生命期较长的对象。

3. Perm(持久代)
用于存放静态文件,如今Java类、方法等。持久代对垃圾回收没有显著影响,但是有些应用可能动态生成或者调用一些class,例如Hibernate等,在这种时候需要设置一个比较大的持久代空间来存放这些运行过程中新增的类。持久代大小通过-XX:MaxPermSize=<N>进行设置。


调优稍等。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值