JDK本地内存追踪NMT
通常情况下, JVM占用的内存不仅仅是-Xmx, -Xms等指定的大小, 因为JVM也是一个应用, 它需要额外的空间去完成它的工作, 除了堆外, JVM会分配内存的地方包括以下这些:
Metaspace: 元数据区, 存储类, 及方法的元数据信息
Threads: 线程, 线程里的栈还是比较耗内存的, 在64位操作系统上, 默认栈的大小为1MB, 当然可以通过-Xss配置。
因为一般情况下线程的数量是没有限制的, 因此可能会占用极其多的内存。
Code Cache: JVM通过JIT把字节码转换成机器指令, 然后把这些指令放到一个非堆区域Code Cache。
配置参数:
-XX:InitialCodeCacheSize: 初始大小
-XX:ReservedCodeCacheSize: 最大的空间大小
Garbage Collection: JVM的垃圾回收器需要使用到一个空间去完成它们的任务, 一些运行时的数据等等, 这个空间使用的更多的是本地内存(native memory)
符号表:
String Pool: JVM复用字面量字符串的地方。
配置参数:
-XX:StringTableSize: 常量池大小
运行时常量池,JVM用来存储编译时的字面量或方法以及属性地址(reference)。
Native Byte Buffers:
开发者可以直接使用本地内存, 如通过JNI的malloc或者NIO的ByteBuffers等。
Native Memory Tracking
那么怎么监控JVM使用到的这些内存吗, 答案就是通过NMT(Native Memory Tracking), 但是使用它之前需要设置JVM的启动参数:
-XX:NativeMemoryTracking, 可能的值为off, 关闭,也为默认值, summary, 显示汇总信息, detail, 显示详细信息。
使用方法:
首先通过jps找到对应的Java程序的pid,然后使用如下命令:
jcmd <pid> VM.native_memory
我在本地运行jcmd后输出结果为:
11132:
Native Memory Tracking:
Total: reserved=3517807KB, committed=548183KB
- Java Heap (reserved=2045952KB, committed=366080KB)
(mmap: reserved=2045952KB, committed=366080KB)
- Class (reserved=1089619KB, committed=46803KB)
(classes #8341)
(malloc=6227KB #11407)
(mmap: reserved=1083392KB, committed=40576KB)
- Thread (reserved=29820KB, committed=29820KB)
(thread #30)
(stack: reserved=29696KB, committed=29696KB)
(malloc=89KB #152)
(arena=35KB #59)
- Code (reserved=251467KB, committed=10383KB)
(malloc=1867KB #4673)
(mmap: reserved=249600KB, committed=8516KB)
- GC (reserved=80655KB, committed=74803KB)
(malloc=5775KB #218)
(mmap: reserved=74880KB, committed=69028KB)
- Compiler (reserved=149KB, committed=149KB)
(malloc=18KB #478)
(arena=131KB #3)
- Internal (reserved=6719KB, committed=6719KB)
(malloc=6655KB #11664)
(mmap: reserved=64KB, committed=64KB)
- Symbol (reserved=11371KB, committed=11371KB)
(malloc=9477KB #85817)
(arena=1894KB #1)
- Native Memory Tracking (reserved=1880KB, committed=1880KB)
(malloc=72KB #1130)
(tracking overhead=1807KB)
- Arena Chunk (reserved=176KB, committed=176KB)
(malloc=176KB)
11132是进程号pid
然后出现的很多reserved是指总共可用的内存大小, 而commited是指已经使用的内存大小。
追踪本地内存的变化
NMT可以让我们看到随时间增长本地内存的变化。
首先需要设置一个对照的内存状态:
jcmd <pid> VM.native_memory baseline
然后过一段时间如果需要查看变化状态即:
jcmd <pid> VM.native_memory detail.diff
NMT通过+和-来显示内存的变化:
Total: reserved=1771487KB +3373KB, committed=491491KB +6873KB
- Java Heap (reserved=307200KB, committed=307200KB)
(mmap: reserved=307200KB, committed=307200KB)
- Class (reserved=1084300KB +2103KB, committed=39356KB +2871KB)
Refer: https://www.baeldung.com/native-memory-tracking-in-jvm
JDK本地内存追踪NMT的更多相关文章
- 十三、jdk命令之Java内存之本地内存分析神器:NMT 和 pmap
目录 一.jdk工具之jps(JVM Process Status Tools)命令使用 二.jdk命令之javah命令(C Header and Stub File Generator) 三.jdk ...
- 第05篇. Tomcat和JDK的内存配置
站在人群,我毫不起眼:活在世上,我不玩心眼! 没有那么远大的目标,但是也不要把我当成傻子! --胖先生 放在前面要说的话:JVM内存分配设置的参数有四个 -Xmx Java Heap最大值,默认值为物 ...
- Linux Kernel 本地内存损坏漏洞
漏洞名称: Linux Kernel 本地内存损坏漏洞 CNNVD编号: CNNVD-201310-663 发布时间: 2013-11-05 更新时间: 2013-11-05 危害等级: 漏洞类 ...
- 2、MyEclipse和Eclipse调优,MyEclipse配置(tomcat和jdk的内存设置),jar引入相关知识点,将Java项目编程web项目的办法
1.WindowàPreferenceàGeneralàWorkspaceàText file encoding都改成UTF-8 2.WindowàPreferenceàGeneralàEdito ...
- 【转】哪个更快:Java堆还是本地内存
译文出处: shenzhang 原文出处:原文链接 使用Java的一个好处就是你可以不用亲自来管理内存的分配和释放.当你用new关键字来实例化一个对象时,它所需的内存会自动的在Java堆中分配.堆 ...
- Java内存模型(JMM)是什么?JMM 通过控制主内存与每个线程的本地内存之间的交互,来提供内存可见性保证
Java内存模型就是一种符合内存模型规范的,屏蔽了各种硬件和操作系统的访问差异的,保证了Java程序在各种平台下对内存的访问都能保证效果一致的机制及规范. Java内存模型是根据英文Java Memo ...
- jdk outMemory内存溢出
参数的含义: -vmargs -Xms256M -Xmx768M -Xss256k -XX:PermSize=256M -XX:MaxPermSize=768M -vmargs 说明后面是vm的参数 ...
- Tomcat和JDK的内存配置
1.jvm内存管理机制: 1)堆(Heap)和非堆(Non-heap)内存 按照官方的说法:"Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配.堆是在 Ja ...
- git跟踪远程分支,查看本地分支追踪和远程分支的关系
跟踪远程分支 如果用git push指令时,当前分支没有跟踪远程分支(没有和远程分支建立联系),那么就会git就会报错 There is no tracking information for the ...
随机推荐
- log4j.properties的配置信息
吃了没日志的亏,以前总以为日志没用,以后要重视起来了,很多错误服务器不会显示,但是页面上就是出错,这个时候就要显示日志了. 日志的代码如下,创建日志文件,文件名为log4j.properties,把这 ...
- vue项目开发期间,配置webpack解决后台接口在不同服务器上的问题 之 二 ( node搭建服务 )
由于今天上午 后端人员把接口都整合都一个服务器了,所以就没有硬关注 上一篇文章的问题, 晚上回来,用node搭了一个简单服务器,测试了下,是没有问题的.代码如下: 一. 自己初始化项目, 1.pack ...
- WinDbg常用命令系列---!findstack
简介 !findstack扩展查找所有包含指定的符号或模块的堆栈.此命令搜索线程调用堆栈中的特定符号,并显示匹配的线程. 使用形式 !findstack Symbol[DisplayLevel] !f ...
- 表格样式、表格css、
.mytab{ border-collapse: collapse;}.mytab tr,.mytab td,.mytab th{ text-align: center; border: 1px so ...
- 【Beta】Scrum meeting 9
目录 写在前面 进度情况 任务进度表 Beta-1阶段燃尽图 遇到的困难 照片 commit记录截图 文档集合仓库 后端代码仓库 技术博客 写在前面 例会时间:5.13 22:30-22:45 例会地 ...
- 冰多多团队-第三次Scrum会议
冰多多团队-第三次Scrum会议 会议基本情况 会议时间:4月9日 21:30 - 21:45 会议地点:新主楼F座2楼沙发休息处 工作情况 团队成员 已完成任务 待完成任务 zpj 接入Action ...
- 第08组 Beta冲刺(2/4)
队名 八组评分了吗 组长博客链接(2分) 组员1李昕晖(组长) 过去两天完成了哪些任务 文字/口头描述 12月9号了解各个小组的进度与难以攻破的地方,晚上安排开会,安排新的冲刺任务. 重新分配小组及个 ...
- C#实体类对应SQL数据库的自增长ID怎么设置?
/// <summary> /// 自增长ID /// </summary> [DatabaseGenerated(DatabaseGeneratedOption.Identi ...
- 带缓存的基于DateTimeFormatter的日期格式化工具类
JAVA中的SimpleDateFormat是非线程安全的,所有在1.8的JDK版本里提供了线程安全的DateTimeFormatter类,由于是线程安全的,故我们可以将此类缓存起来多次利用提高效率. ...
- nodejs命令行执行时带参数
nodejs命令行执行时带参数 转 https://www.jianshu.com/p/474e6d76f867 今天项目里突然想在初始化时跑一些数据,于是想起以前在python时可以在命令行里带 ...