- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 tomcat 启动中,我将 -xms 、 -xmx 设置为 1GB。当我监视内存时在 VisualVM 内
当我对内存进行采样时,它不会显示准确的内存使用情况,直到我按“快照”,然后利用内存的 java 类才会显示正确的模式和实例计数。为什么会这样?
另外,当我将 tomcat 内存设置为 1GB 时,内存会继续增加 zip-zat 并上升到大约 960mb。直到我按“perform gc”并且内存回到200mb..
您认为需要创建调度程序来强制每天午夜在 jvm 上执行 Perform.gc() 吗?
我的描述中的任何评论
最佳答案
我相信您在这里看到的是并发垃圾收集器正在执行年轻代清理,但堆不断搅拌,因此它无法获取老一代收集的所有引用。当您点击“执行 GC”按钮时,您正在执行“停止世界”收集,该收集会阻止所有线程、卡住堆并允许发生更大的收集。我在这里主要关心的是 - 是否曾经发生过大型收集(x 小时后)?您是否在较小的堆中看到 OutOfMemory 错误?
1) 您是否打开了自动刷新按钮?也可能是分析器在拍摄快照之前执行一次小型 GC(Eden 空间)。
2) 这是完全正常的。垃圾收集需要时间和资源(处理器周期)。如果您将堆设置为很大的大小,它将等到它达到一定百分比,然后触发垃圾收集本身。我认为默认的可用空间与 Activity 对象的比率在 40% 到 70% 之间,我知道 tomcat 在版本 5 中专门改变了垃圾收集的方式,tomcat v4 存在性能问题,因为它花费了大量时间运行垃圾收集器。您可能想在这里做一些研究,看看 tomcat 是否有自定义垃圾收集选项。
3) 不。几乎满的堆正是您所追求的。缩小堆可能是有意义的,这样完整的垃圾回收就不会花费这么长时间。这是大量垃圾收集(暂停)和长时间垃圾收集(长时间暂停)之间的权衡。每个应用程序都是不同的,因此我通常从默认值开始,然后根据需要进行调整。如果您感兴趣,有很多垃圾收集(和备用收集器)选项。
Java 6 FAQ , Whitepaper关于java - VisualVM监控内存使用情况,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4020765/
使用 VisaulVM,我想将其作为数据获取,而不应用图像处理算法......我该怎么做?我认为这不会来自快照。 我不确定 VisualVM 和 jVisualVM 有何不同,命名肯定令人困惑,但我正
我正在从 VisualVM 1.3.2 迁移到 1.3.3,并希望将我设置的所有远程服务器和应用程序迁移到这个新安装。 我查看了 %HOMEPATH%\Application Data.visualv
我的查询结果有数百万行。我已经修改了visualvm.conf -J-DOQLController.limitResults=1000000 目前,作为一种解决方法,我运行查询,然后将结果复制并粘贴到
我正在运行 JDK 1.8.0_66 JVisualVM 实用程序,并希望使用 MBeans 浏览器来监视我的 Coherence 应用程序。 根据Oracle教程,我必须首先安装MBeans插件。所
我的查询结果有数百万行。我已经修改了visualvm.conf -J-DOQLController.limitResults=1000000 目前,作为一种解决方法,我运行查询,然后将结果复制并粘贴到
我正在使用 VisualVM 来监控许多 JAVA 应用程序,我想安装一些在这个应用程序中可用的插件。不幸的是,“可用插件”选项对我自己不起作用,因为我相信我可能被阻止了通过公司代理。 我可以如何以及
我在使用“Java VisualVM”时遇到了一些麻烦,它似乎是 Oracle 品牌的,而且关于我正在运行版本 1.6.0_51 的页面声明的丑陋之处。 特别是让我失望的一件事是,我一直在运行这个非常
如果我使用适用于 Java8 的 AdoptOpenJDK HotSpot 构建,我可以使用 VisualVM 监控应用程序。 如果我使用 OpenJ9 版本,VisualVM 会显示错误“无法检测到
我可以附加到 surefire 进程,但尝试分析它显示采样: CPU sampling: Not available. Failed to create JMX connection to targe
在我的项目中,我们使用一个小型的 Java 分析工具。它显示了我们的应用程序加载到内存中的所有对象,并实时反射(reflect)了对象的变化。我们主要用它来调试。 我的问题是:它如何运作?外部应用程序
我在 visualvm v1.3.8 中找到所需的对象: filter(heap.objects("java.lang.String"), "/hibernate\\.ejb\\.naming/(it
我正在尝试为 VisualVM 安装一些插件,但它一直卡在下面的屏幕上 - 告诉我“请等待安装程序发现插件依赖项”。我运行的是 Ubuntu 12.04。当我尝试从“可用插件”列表中安装它们时,以及当
我正在尝试为 VisualVM 安装一些插件,但它一直卡在下面的屏幕上 - 告诉我“请等待安装程序发现插件依赖项”。我正在运行 Ubuntu 12.04。当我尝试从“可用插件”列表安装它们时,以及当我
我正在使用 VisualVM(内置于 JDK1.6)来分析我的 Java 应用程序以查找内存泄漏。我正在使用堆转储和探查器(内存监视器)这两个 VisualVM 功能...有一些不一致之处,我无法理解
我正在使用 VisualVM 来分析 javafx 8 应用程序,该应用程序执行一些绘图操作,并且使用的内存比我想要的多得多。它似乎没有泄漏,但由于某种原因,我的总堆永远不会减少,即使当我选择不同的文
正在监视 Java 应用程序的线程锁定情况, 在 visualvm 的监控标签下, Activity 线程:112Live Peak:126守护线程:99开始总数:135,742 这是什么意思?我觉得
这似乎是一个荒谬的问题。在 google 上搜索 VisualVM 会得到很多信息,包括据称很容易连接到正在运行的 JVM 和监视器。 嗯,事实并非如此。我不知道如何将 VisualVM 连接到我正在
我正在尝试分析一个应用程序,我有很多类型为 sim.core.EndPoint$2 的实例 当我检查这些实例时,我确认它们不是 sim.core.EndPoint 类型,它们似乎是一个 EndPoin
今天我对得到的 Visual VM 分析结果感到困惑。 我有以下简单的Java方法: public class Encoder { ... private BitString encode(I
我已将tomcat(已分配8GB堆内存)连接到visualvm。在 VisualVM 中,在“采样器”->“内存”选项卡下,分配的总内存显示为 17GB(18470717672 字节)。但只分配了8G
我是一名优秀的程序员,十分优秀!