我编写的java应用程序遇到了一个问题,导致硬件性能问题。问题(我相当肯定)是,我运行应用程序的几台机器只有1GB内存。启动java应用程序时,我将堆大小设置为-Xms 512 m -Xmx 1024m。
我的第一个问题是,我的假设正确吗?这显然会导致性能问题,因为我正在将所有机器内存分配给java堆吗?
这就引出了另一个问题。我在应用程序上运行j控制台并监视应用程序的内存使用情况。我看到的是,应用程序在启动时消耗大约30 is,大约150 is,垃圾收集器运行,然后下降到30 is。我还看到在pid上使用顶部的情况是,应用程序首先使用大约6%的内存,然后慢慢上升到大约20%。我不明白这点。为什么当我将1GB内存分配给它时,它的内存使用率只有20%。不是应该100%吗。此外,为什么它使用这么多内存(20%),而它似乎从来没有超过150‘t的应用程序?
我认为很明显,我需要调整我的Xms和Xmx,这应该可以解决这个问题,但是我正在努力更好地理解到底发生了什么。
发布于 2017-08-18 16:22:55
内存使用的两种可能性:
你的应用程序不需要那么多内存
或
你的应用程序使用的内存不够快。
发生了什么:
垃圾收集器有几个点将在其中执行:
如果选项1 (通常影响小得多的快速收集)可以控制您的内存使用,那么它将不会击中完整的集合,除非JVM选项设置为按计划运行完整的集合。
在您的应用程序中,我将开始设置较低的xmx/xms值,以便为操作系统留出更多有保障的资源,并且可能会防止分页。
https://stackoverflow.com/questions/45760977
复制相似问题