gpt4 book ai didi

java - 如何减少 Sun/Oracle JVM 内部开销?

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:24:32 25 4
gpt4 key购买 nike

此问题专门针对 在 Linux x86-64 上运行的 Sun Java JVM。我试图弄清楚 为什么即使我设置了堆和非堆限制,Sun JVM 也会占用如此多的系统物理内存

我正在运行的程序是具有多个插件/功能的 Eclipse 3.7。最常用的功能是 PDT、EGit 和 Mylyn。我使用以下命令行开关启动 Eclipse:

-nosplash -vmargs -Xincgc -Xms64m -Xmx200m -XX:NewSize=8m -XX:PermSize=80m -XX:MaxPermSize=150m -XX:MaxPermHeapExpansion=10m -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=70 -XX:+UseCMSInitiatingOccupancyOnly -XX:+UseParNewGC -XX:+CMSIncrementalMode -XX:+CMSIncrementalPacing -XX:CMSIncrementalDutyCycleMin=0 -XX:CMSIncrementalDutyCycle=5 -XX:GCTimeRatio=49 -XX:MaxGCPauseMillis=50 -XX:GCPauseIntervalMillis=1000 -XX:+UseCMSCompactAtFullCollection -XX:+CMSClassUnloadingEnabled -XX:+DoEscapeAnalysis -XX:+UseCompressedOops -XX:+AggressiveOpts -Dorg.eclipse.swt.internal.gtk.disablePrinting

值得注意的是开关:

-Xms64m -Xmx200m -XX:NewSize=8m -XX:PermSize=80m -XX:MaxPermSize=150m

这些开关应将 JVM 堆限制为最大 200 MB,将非堆限制为 150 MB(JConsole 标记的“CMS 永久生成”和“代码缓存”)。从逻辑上讲,JVM 应该总共占用 350 MB 加上 JVM 所需的内部开销。

实际上,JVM 为我当前的 Eclipse 进程占用了 544.6 MB,这是由 ps_mem.py ( http://www.pixelbeat.org/scripts/ps_mem.py ) 计算的,它计算了 Linux 2.6+ 内核保留的实际物理内存页。 这是 35% 或大约 200MB 的内部 Sun JVM 开销!

关于如何减少这种开销的任何提示?

这里有一些额外的信息:

$ ps auxw
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
me 23440 2.4 14.4 1394144 558440 ? Sl Oct12 210:41 /usr/bin/java ...

根据 JConsole,该进程使用了​​ 160 MB 的堆内存和 151 MB 的非堆内存。

我并不是说我负担不起使用额外的 200MB 来运行 Eclipse,但如果有办法减少这种浪费,我宁愿将那 200MB 用于内核 block 设备缓冲区或文件缓存。此外,我对其他 Java 程序也有类似的经验——也许我可以通过类似的调整来减少所有这些程序的开销。

更新:发布问题后,我找到了之前发给 SO 的帖子: Why does the Sun JVM continue to consume ever more RSS memory even when the heap, etc sizes are stable?看来我应该使用pmap 来调查问题。

最佳答案

我认为您的Eclipse 环境内存消耗高的原因是使用了SWT。 SWT 是 JVM 堆之外的本 map 形库,更糟糕的是,Linux 上的实现并未真正优化。

我不认为真的有机会减少关于堆外内存的 eclipse 环境的内存消耗。

关于java - 如何减少 Sun/Oracle JVM 内部开销?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7805743/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com