Kon*_*rad 7 java memory jvm pmap
我在docker容器内的Java 8上运行了一个java应用程序.该过程启动Jetty 9服务器并部署Web应用程序.传递以下JVM选项:-Xms768m -Xmx768m.
最近我注意到这个过程耗费了大量的内存:
$ ps aux 1
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
app 1 0.1 48.9 5268992 2989492 ? Ssl Sep23 4:47 java -server ...
$ pmap -x 1
Address Kbytes RSS Dirty Mode Mapping
...
total kB 5280504 2994384 2980776
$ jcmd 1 VM.native_memory summary
1:
Native Memory Tracking:
Total: reserved=1378791KB, committed=1049931KB
- Java Heap (reserved=786432KB, committed=786432KB)
(mmap: reserved=786432KB, committed=786432KB)
- Class (reserved=220113KB, committed=101073KB)
(classes #17246)
(malloc=7121KB #25927)
(mmap: reserved=212992KB, committed=93952KB)
- Thread (reserved=47684KB, committed=47684KB)
(thread #47)
(stack: reserved=47288KB, committed=47288KB)
(malloc=150KB #236)
(arena=246KB #92)
- Code (reserved=257980KB, committed=48160KB)
(malloc=8380KB #11150)
(mmap: reserved=249600KB, committed=39780KB)
- GC (reserved=34513KB, committed=34513KB)
(malloc=5777KB #280)
(mmap: reserved=28736KB, committed=28736KB)
- Compiler (reserved=276KB, committed=276KB)
(malloc=146KB #398)
(arena=131KB #3)
- Internal (reserved=8247KB, committed=8247KB)
(malloc=8215KB #20172)
(mmap: reserved=32KB, committed=32KB)
- Symbol (reserved=19338KB, committed=19338KB)
(malloc=16805KB #184025)
(arena=2533KB #1)
- Native Memory Tracking (reserved=4019KB, committed=4019KB)
(malloc=186KB #2933)
(tracking overhead=3833KB)
- Arena Chunk (reserved=187KB, committed=187KB)
(malloc=187KB)
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,RSS(2,8GB)与VM本机内存统计实际显示的内容之间存在巨大差异(提交1.0GB,保留1.3GB).
为什么会有这么大的差异?我知道RSS也显示了共享库的内存分配,但是在分析了pmap详细输出之后,我意识到它不是共享库的问题,而是内存被某些东西所消耗,称为[anon]结构.为什么JVM分配了这么多匿名内存块?
我正在搜索并发现以下主题: 为什么JVM报告的内存比linux进程驻留集大小更多? 然而,描述的情况有所不同,因为RSS显示的内存使用量少于JVM统计数据.我有相反的情况,无法弄清楚原因.
我在 Apache Spark 作业中遇到了类似的问题,我们将应用程序作为 fat jar 提交,在分析线程转储后,我们发现 Hibernate 是罪魁祸首,我们过去常常在实际使用的应用程序启动时加载 hibernate 类java.util.zip.Inflater.inflateBytes要读取 hibernate 类文件,这超出了我们的本机驻留内存使用量近 1.5 GB,这是 hibernate 中针对此问题提出的一个错误
https://hibernate.atlassian.net/browse/HHH-10938?attachmentOrder=desc,评论中建议的补丁对我们有用,希望这有帮助。
| 归档时间: |
|
| 查看次数: |
6549 次 |
| 最近记录: |