- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的应用程序遇到一些内存问题,需要帮助理解这些统计信息。
Unix“top”显示了我的进程的这些统计数据-
VSZ: 37.4g
RSS: 20.0g
因此,这意味着 20g 当前已换入进程并正在使用。
但是,当我使用运行时类从应用程序中打印统计信息时,我得到:
Runtime.totalMemory() : 9.8G
Runtime.freeMemory() : 3.6G
Runtime.maxMemory() : 14.3G
为什么 [Runtime.totalMemory() - Runtime.freeMemory()] 与 RSS 不匹配?这是进程当前使用的内存。两个数字之间存在巨大差异。
此外,运行时是否会将未使用的内存(Runtime.freeMemory())返还给操作系统以供其他进程使用?
请注意,我的应用程序正在使用共享和复制缓存设置的对等 GemFire 缓存系统中运行。我需要优化应用程序以减少内存占用。
最佳答案
Runtime.totalMemory 显示当前可用内存。 Java 延迟分配内存。
Also, does the runtime give back the unused memory (Runtime.freeMemory()) back to OS for use by other processes?
没有。如果Java分配了内存(totalMemory),它现在在java进程中。
RSS: 20.0g 14.3G
正如已经提到的,Java 除了堆之外还使用内存。Gemfire 还使用堆外内存 ( check this )。尝试在 VisualVM-Buffer Monitor 中查看它们。
您的基础设施(操作系统、虚拟机)是什么?
如果您无法使用标准工具,您可能应该使用 JMX 编写自己的可服务性代理 ( for example )
更新
As per doc, by default Gemfire uses JVM Heap.
好的
Why is RSS consistently showing 20G for a process that is using only ~10G of heap memory.
如果您仍然询问,我会提供更多详细信息。 java内存使用情况是怎样的?
要查看默认值,您可以运行:
java -XX:+UnlockDiagnosticVMOptions -XX:+PrintFlagsFinal -version
要查看适合您的特定进程的选项,您可以运行:
jps -lvm
Is there an command line tool in unix to determine the rest usage?
对于其中一些人来说是的。对于其中一些人来说没有。
对于直接内存,您可以尝试 sun.misc.SharedSecrets.getJavaNioAccess().getDirectBufferPool().getMemoryUsed()。
以cmd为例:
jcmd <pid> VM.native_memory baseline
但这取决于运行设置(NativeMemoryTracking)。您可以阅读如何启用 native 内存跟踪 here .
在 Linux 中你还可以使用:
pmap -x <pid>
总之,这可能无关紧要,因为您的任务:
Note that my applications are running in a peer to peer GemFire caching system set up with shared and replicated caches. I need to optimize the application to reduce memory footprint.
并且您不能影响 native 内存使用。我想看看jmap util,它可以显示类直方图。您应该检查 GemFire 中大小较大的对象并检查这些对象,可能您存储在缓存数据中,但这些对象不应该存在。我的意思是,在优化缓存的实践中,我会检查对象和字段,看看哪些字段真正频繁,哪些字段不频繁。另一种方法是检查您的序列化机制和对象布局。
正如我提到的,您可以使用可服务性代理:
import com.sun.tools.attach.VirtualMachine;
import sun.tools.attach.HotSpotVirtualMachine;
import java.io.InputStream;
public class JMemoryMain {
public static void main(String[] args) throws Exception {
final int pid = JMemoryMainUtils.getPid(args);
final HotSpotVirtualMachine vm = (HotSpotVirtualMachine) VirtualMachine.attach(String.valueOf(pid));
final byte[] buffer = new byte[1024];
try (InputStream is = vm.heapHisto()) {
for (int read; (read = is.read(buffer)) > 0;) {
System.out.write(buffer, 0, read);
}
}
vm.detach();
}
}
您需要 JDK 中的依赖项中的 tools.jar 来运行它。它也可以打印类直方图,但有时可以工作,而 jmap 则不能。另外,当您需要等待很长时间时,在计算直方图时,您可以使用 VM.getSystemDictionary() 并仅查找您的类。而且,如果由于开销而无法启用 NMT,这将很有用。
关于java - 为什么unix和Java运行时显示的统计数据存在差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45964918/
正如标题所暗示的那样,我无法弄清楚 Unix 内核如何将逻辑文件偏移量转换为逻辑块号,然后从 i-node 中检索它。 作为引用,我要求对 Maurice J. Bach 在“UNIX 操作系统的设计
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 8年前关闭。 Improve this q
我在互联网上做了一些研究,但仍然很困惑。 UNIX 时间是像 GMT/UTC 那样的通用时间还是像本地时间一样因地而异? 我知道 UNIX 时间是从 1970 年 1 月 1 日格林威治标准时间 00
您如何评估 Unix 系统管理员。 Unix 管理员应该具备哪些编程能力? 最佳答案 我用于快速过滤器的一些: 什么是 fork 炸弹,它是好是坏? 给我一个单行命令,计算日志文件中有多少行从昨天的日
谁能告诉我字典文本文件在 UNIX 系统上的位置?或者我在哪里可以获得一个好的字典文本文件?我目前一直在使用来自 SUN 的文本文件,但它包含不带句点的缩写(否则我可以删除它们)。有人能指出我正确的方
在我的 Ubuntu 12 vps 上,我正在运行一个完整的比特币节点。当我第一次启动它时,它使用了大约 700mb 的内存。如果我 24 小时后回来 (free -m) 将如下所示: total
我想编写一个 unix/linux 程序,它将使用一个配置文件。 我的问题是,我应该把文件的位置放在哪里? 我可以将位置(如 /etc )“硬编码”到程序本身中。 但是,我希望它,如果没有权限的用户可
在UNIX脚本编程中,cat是可以将2个文件组合在一起的命令: cat file1 file2 > file3 通过合并前两个生成第三个。 另外,cat可以与管道一起使用: cat file1 | t
我有一个通过 ssh 连接到外部机器的终端,并且有一个进程在其中运行。 是否可以将执行移到后台,以便我可以关闭 ssh 连接而无需终止它?如果是这样怎么办? 最佳答案 按 control + Z,这将
我正在试验我自己的 BSD 或 Linux 发行版。我想以对最终用户有意义的方式组织系统文件。我希望他们能够访问系统,而不会出现 *nixes 留下的所有文件困惑。 有没有办法在不丢失动态链接的情况下
这条评论让我感到困惑:“kill -l 通常会列出所有信号”。我认为信号意味着量化的能量。 [已添加] 请澄清 Unix 中的(计算)信号和物理信号。它们是完全不同的概念吗? [已添加] 范式之间是否
fuser 命令让我知道哪些进程正在使用文件或目录。 我正在寻找相反的命令:让我知道进程正在使用哪些文件。 更新 忘了说它是针对 Solaris 系统的。 最佳答案 lsof -p 来自 here
如果我有一个叫做“orange”的词,我如何将它拆分成单独的字符。 我的输出应该是: o r a n g e 最佳答案 echo orange | fold -w 1 输出 o r a n g e 关
和有什么区别工作和一个 流程在 Unix 中?你能举个例子吗? 最佳答案 作业是由 shell 启动的进程。 shell 在作业表中跟踪这些。作业命令显示事件后台进程的列表。他们得到一个 jobspe
unix 如何处理带空格和参数的完整路径名? 在 Windows 中,我们引用路径并在其后添加命令行参数,在 unix 中如何? "c:\foo folder with space\foo.exe"
我必须合并具有相同标题的多个CSV文件。 我必须保留第一个文件的 header ,并删除所有其他文件的 header ,然后合并它们并创建一个主文件。 文件1: Id,city,name ,locat
我需要在两个字段上加入两个文件。但是,即使连接失败,我也应该检索文件 1 中的所有值,就像左外连接一样。 文件 1: 01|a|jack|d 02|b|ron|c 03|d|tom|e 文件2: 01
在 Solaris, HP-UX 上获取进程大小的正确方法是什么?和 AIX ?我们应该使用 top或 ps -o vsz或者是其他东西? 最佳答案 vsize的确切定义, rss , rprvt ,
我在文件上使用了“touch”,更新了文件的时间戳,但父目录的时间戳没有改变。但是,(如预期)当我在父目录中创建新文件时,该目录的时间戳确实发生了变化。 类 UNIX 操作系统(特别是 AIX)使用什
一般来说,当我们从多个进程向 UNIX 中的文件追加内容时,我们可以认为什么是理所当然的?是否有可能丢失数据(一个进程覆盖另一个进程的更改)?数据有可能被破坏吗? (例如,每个进程都将每个追加一行追加
我是一名优秀的程序员,十分优秀!