内存溢出及Jvm监控工具

内存泄露与内存溢出

内存溢出 out of memory,是指程序在申请内存时,没有足够的内存空间供其使用,出现out of memory。

内存泄露 memory leak,是指程序在申请内存后,无法释放已申请的内存空间。一次内存泄露危害可以忽略,但内存泄露堆积后果很严重,无论多少内存,迟早会被占光。
memory leak会最终会导致out of memory!

内存溢出分类

堆内存溢出
堆内存中存在大量对象,这些对象都有被引用,当所有对象占用空间达到堆内存的最大值,就会出现内存溢出OutOfMemory:Java heap space
永久代溢出
类的一些信息,如类名、访问修饰符、字段描述、方法描述等,所占空间大于永久代最大值,就会出现OutOfMemoryError:PermGen space

内存泄露检测手段

Jdk/bin目录下有很多检测工具
图形界面(需要更新测试机配置文件):
Jconsole
Jvisualvm
命令行工具:
Jstat –gcutil pid 1000 100
Jmap –histo pid | head -20
Jmap –heap pid

 1 [[email protected] bin]# jmap -heap 2384   //打印java heap堆内存信息
 2 Attaching to process ID 2384, please wait...
 3 Debugger attached successfully.
 4 Client compiler detected.
 5 JVM version is 11.0-b15
 6
 7 using thread-local object allocation.
 8 Mark Sweep Compact GC
 9
10 Heap Configuration:
11    MinHeapFreeRatio = 40
12    MaxHeapFreeRatio = 70
13    MaxHeapSize      = 268435456 (256.0MB)
14    NewSize          = 131072000 (125.0MB)
15    MaxNewSize       = 131072000 (125.0MB)
16    OldSize          = 4194304 (4.0MB)
17    NewRatio         = 12
18    SurvivorRatio    = 8
19    PermSize         = 12582912 (12.0MB)
20    MaxPermSize      = 67108864 (64.0MB)
21
22 Heap Usage:
23 New Generation (Eden + 1 Survivor Space):
24    capacity = 117964800 (112.5MB)
25    used     = 102007440 (97.28187561035156MB)
26    free     = 15957360 (15.218124389648438MB)
27    86.4727783203125% used
28 Eden Space:
29    capacity = 104857600 (100.0MB)
30    used     = 90339496 (86.15445709228516MB)
31    free     = 14518104 (13.845542907714844MB)
32    86.15445709228516% used
33 From Space:
34    capacity = 13107200 (12.5MB)
35    used     = 11667944 (11.127418518066406MB)
36    free     = 1439256 (1.3725814819335938MB)
37    89.01934814453125% used
38 To Space:
39    capacity = 13107200 (12.5MB)
40    used     = 0 (0.0MB)
41    free     = 13107200 (12.5MB)
42    0.0% used
43 tenured generation:
44    capacity = 137363456 (131.0MB)
45    used     = 40348976 (38.47978210449219MB)
46    free     = 97014480 (92.52021789550781MB)
47    29.373879469078005% used
48 Perm Generation:
49    capacity = 12845056 (12.25MB)
50    used     = 12656048 (12.069747924804688MB)
51    free     = 189008 (0.1802520751953125MB)
52    98.52855448820154% used

配置tomcat jvm参数

编写接口脚本

跑5分钟……

jvisualvm远程连接虚拟机监控

可以看到堆内存到达了顶点,发生了垃圾回收却没有起作用。像这样暴力的,哈哈

时间: 2024-08-05 15:16:54

内存溢出及Jvm监控工具的相关文章

内存溢出与jvm参数配置

第一类内存溢出,也是大家认为最多,第一反应认为是的内存溢出,就是堆栈溢出: 那什么样的情况就是堆栈溢出呢?当你看到下面的关键字的时候它就是堆栈溢出了: Java.lang.OutOfMemoryError: ......Javaheap space..... 也就是当你看到heap相关的时候就肯定是堆栈溢出了,此时如果代码没有问题的情况下,适当调整-Xmx和-Xms是可以避免的,不过一定是代码没有问题的前提,为什么会溢出呢,要么代码有问题,要么访问量太多并且每个访问的时间太长或者数据太多,导致数

性能测试三十六:内存溢出和jvm常见参数

堆内存溢出: 此种溢出,加内存只能缓解问题,不能根除问题,需优化代码堆内存中存在大量对象,这些对象都有被引用,当所有对象占用空间达到堆内存的最大值,就会出现内存溢出OutOfMemory:Java heap space 永久代溢出 如果发生,则是在初始化的时候,空间太小,解决办法,扩大空间类的一些信息,如类名.访问修饰符.字段描述.方法描述等,所占空间大于永久代最大值,就会出现OutOfMemoryError:PermGen space 内存溢出的检测方法:pid=1730 Jdk/bin目录下

性能测试三十六:内存溢出和JVM常见参数及JVM参数调优

堆内存溢出: 此种溢出,加内存只能缓解问题,不能根除问题,需优化代码堆内存中存在大量对象,这些对象都有被引用,当所有对象占用空间达到堆内存的最大值,就会出现内存溢出OutOfMemory:Java heap space 永久代溢出 如果发生,则是在初始化的时候,空间太小,解决办法,扩大空间类的一些信息,如类名.访问修饰符.字段描述.方法描述等,所占空间大于永久代最大值,就会出现OutOfMemoryError:PermGen space 内存溢出的检测方法:pid=1730 Jdk/bin目录下

一次内存溢出的填坑经历

在项目运行过程中,可能会出现内存溢出,内存溢出的原因多种多样,而在内存溢出后,我们如何查找和分析内存溢出的原因呢?这里来说一说我遇到的次遇到的内存溢出经历. 大致情况是这样的:应用在启动后,过一段时间(这个时间不确定),内存忽然爆满,然后频繁的YGC,一会过后,老年代爆满,然后是频繁的FGC,最终撑爆内存,抛出OOM.重启应用后,还是这个过程. 1.查看java进程的内存使用情况和GC情况 通过jastat工具查看GC情况,以及各generation占用比例: jstat -gcutil <pi

JVM内存监视手段和内存溢出解决方案

引言 本文仅关注一些常见的虚拟机内存监视手段,以及JVM运行时数据区各个部分内存溢出的发生和对应的解决方案,总体来说属于概括性总结,涉及相对不是很深入,目的是让自己和其它初学者有一个框架性.概念性的了解,当遇到问题时有迹可循.不至于不知所措. 一.虚拟机内存监视手段 虚拟机常出现的问题包括:内存泄露.内存溢出.频繁GC导致性能下降等,导致这些问题的原因可以通过下面虚拟机内存监视手段来进行分析,具体实施时可能需要灵活选择,同时借助两种甚至更多的手段来共同分析. 比如GC日志可以分析出哪些GC较为频

JVM:内存监视手段及各区域内存溢出解决

转载请务必注明出处: jiq?钦's technical Blog - 季义钦 引言 本文仅关注一些常见的虚拟机内存监视手段,以及JVM运行时数据区各个部分内存溢出的发生和对应的解决方案,总体来说属于概括性总结,涉及相对不是很深入,目的是让自己和其它初学者有一个框架性.概念性的了解,当遇到问题时有迹可循.不至于不知所措. 一.虚拟机内存监视手段 虚拟机常出现的问题包括:内存泄露.内存溢出.频繁GC导致性能下降等,导致这些问题的原因可以通过下面虚拟机内存监视手段来进行分析,具体实施时可能需要灵活选

Tomcat中JVM内存溢出及合理配置

Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个Java虚拟机.Tomcat的内存溢出本质就是JVM内存溢出,所以在本文开始时,应该先对Java JVM有关内存方面的知识进行详细介绍. 一.Java JVM内存介绍 JVM管理两种类型的内存,堆和非堆.按照官方的说法:"Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配.堆是在 Java 虚拟机启动时创建的.""在JVM中堆之外的内存称为非堆内存(Non-heap

生产环境-jvm内存溢出-jprofile问题排查

通常来说,分析堆内存快照(Heap Dump)是一个很好的定位手段 ,开启了dump的参数: -XX:+HeapDumpOnOutOfMemoryError 有了这个参数,当我们不得不面对内存溢出异常的时候会节约大量的时间.默认情况下,堆内存快照会保存在JVM的启动目录下名为java_pid<pid>.hprof 的文件里(在这里<pid>就是JVM进程的进程号) dump的内容有2G,先进行压缩打包,传输至本地(scp) tar -czvf dump.tar java_pid48

JVM内存溢出及配置

一.Java JVM内存介绍 JVM管理两种类型的内存,堆和非堆.按照官方的说法:"Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配.堆是在 Java 虚拟机启动时创建的.""在JVM中堆之外的内存称为非堆内存(Non-heap memory)".简单来说堆就是Java代码可及的内存,是留给开发人员使用的:非堆就是JVM留给自己用的,所以方法区.JVM内部处理或优化所需的内存(如JIT编译后的代码缓存).每个类结构(如运行时常数池.