- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我们正在 Domino 8.5.2 上构建使用自定义 Java Bean 的 xPages 应用程序,开发服务器有时会遇到 java/lang/OutOfMemoryError。重新启动 http 任务后,一切都恢复正常,但如果它发生在客户的服务器上,这绝对是一个 killer 。因此,我查看了 Eclipse Memory Analysis 中的堆转储,并检查了最重要的消费者,我得到以下结果:
显然,BCCPropertyStore 类被实例化得如此频繁,以至于它占据了整个堆的 20%,尽管它应该是单例的。类(class)是这样开始的:
public class BCCPropertyStore {
// Constants
private static final String CLASS_NAME = "BCCPropertySynch ";
private static BCCPropertyStore instance = new BCCPropertyStore();
...
public static BCCPropertyStore getInstance() {
return instance;
}
每次使用它时,我们都用 BCCPropertyStore.getInstance() 调用它,它是静态的,所以我的理解是不应该有它的多个实例(Java bean 通常在应用程序范围内,所以我也不明白为什么它们应该有多个实例)。然而,如果我查看重复的类,就会发现许多 xPages 类出现的频率比应有的要高得多:
没有数千名登录应用程序的用户可以为他们创建所有这些实例,只有我和一位开发人员同事。 HTTPJVMMaxHeapSize 设置为 256M,理论上对于这样大小的应用程序来说应该绰绰有余。
为什么 JVM 会创建如此多无用的类实例,直到内存耗尽,并且为什么它们没有被垃圾收集器消灭?这是 xPages 特有的问题还是我错过了什么?
更新
今天又出现了这个错误,我也没有意识到。我按照下面的建议将 BCCPropertyStore 更改为枚举,显然这没有改变任何内容,因为堆转储看起来与我之前发布的屏幕截图几乎相同。
是否有任何工具可以让我们在 JVM 运行时监控其内存使用情况,或者类似的工具可以帮助我们确定修复和建议是否有效?
这是堆栈跟踪:
2013-05-07T10:44:32.441+02:00 java.lang.RuntimeException: com.ibm.xsp.FacesExceptionEx: java.lang.OutOfMemoryError at com.ibm.designer.runtime.domino.adapter.ComponentModule.initModule(ComponentModule.java:433) at com.ibm.domino.xsp.module.nsf.NSFComponentModule.initModule(NSFComponentModule.java:427) at com.ibm.domino.xsp.module.nsf.NSFService.loadModule(NSFService.java:561) at com.ibm.domino.xsp.module.nsf.NSFService.doServiceInternal(NSFService.java:521) at com.ibm.domino.xsp.module.nsf.NSFService.doService(NSFService.java:342) at com.ibm.designer.runtime.domino.adapter.LCDEnvironment.doService(LCDEnvironment.java:304) at com.ibm.designer.runtime.domino.adapter.LCDEnvironment.service(LCDEnvironment.java:261) at com.ibm.domino.xsp.bridge.http.engine.XspCmdManager.service(XspCmdManager.java:291) Caused by: com.ibm.xsp.FacesExceptionEx: java.lang.OutOfMemoryError at com.ibm.xsp.config.CLBootStrap.initContext(CLBootStrap.java:73) at com.ibm.xsp.config.BootStrap.init(BootStrap.java:60) at com.ibm.xsp.config.ConfigureCoreListener.contextInitialized(ConfigureCoreListener.java:58) at com.ibm.designer.runtime.domino.adapter.ComponentModule.initModule(ComponentModule.java:425) ... 7 more Caused by: java.lang.OutOfMemoryError at java.util.Hashtable.newEntry(Hashtable.java:91) at java.util.Hashtable.put(Hashtable.java:766) at java.util.PropertyPermissionCollection.add(PropertyPermissionCollection.java:40) at java.security.Permissions.add(Permissions.java:98) at org.apache.harmony.security.fortress.PolicyUtils.toPermissionCollection(PolicyUtils.java:541) at org.apache.harmony.security.fortress.DefaultPolicy.getPermissions(DefaultPolicy.java:242) at org.apache.harmony.security.fortress.DefaultPolicy.implies(DefaultPolicy.java:365) at java.security.ProtectionDomain.implies(ProtectionDomain.java:159) at java.security.AccessController.checkPermission(AccessController.java:98) at java.lang.SecurityManager.checkPermission(SecurityManager.java:533) at org.eclipse.osgi.framework.internal.core.Framework.checkAdminPermission(Framework.java:1299) at org.eclipse.osgi.framework.internal.core.BundleHost.getResource(BundleHost.java:266) at com.ibm.domino.xsp.module.nsf.Activator.findResource(Activator.java:84) at com.ibm.domino.xsp.module.nsf.Activator.findResource(Activator.java:103) at com.ibm.domino.xsp.module.nsf.Activator.findResource(Activator.java:103) at com.ibm.domino.xsp.module.nsf.Activator.findResource(Activator.java:67) at com.ibm.domino.xsp.module.nsf.NotesClientClassLoader.getResource(NotesClientClassLoader.java:130) at java.lang.ClassLoader.getResource(ClassLoader.java:438) at com.ibm.domino.xsp.module.nsf.ModuleClassLoader.getResource(ModuleClassLoader.java:117) at java.lang.ClassLoader.getResourceAsStream(ClassLoader.java:503) at javax.xml.parsers.SecuritySupport$4.run(Unknown Source) at java.security.AccessController.doPrivileged(AccessController.java:202) at javax.xml.parsers.SecuritySupport.getResourceAsStream(Unknown Source) at javax.xml.parsers.FactoryFinder.findJarServiceProvider(Unknown Source) at javax.xml.parsers.FactoryFinder.find(Unknown Source) at javax.xml.parsers.SAXParserFactory.newInstance(Unknown Source) at org.apache.commons.digester.Digester.getFactory(Digester.java:512) at org.apache.commons.digester.Digester.getParser(Digester.java:686) at org.apache.commons.digester.Digester.getXMLReader(Digester.java:902) at org.apache.commons.digester.Digester.parse(Digester.java:1548) at com.sun.faces.config.ConfigureListener.parse(ConfigureListener.java:1229) at com.sun.faces.config.ConfigureListener.contextInitialized(ConfigureListener.java:328) at com.ibm.xsp.config.CLBootStrap.initContext(CLBootStrap.java:65) ... 10 more 2013-05-07T10:44:33.879+02:00 java.lang.OutOfMemoryError at java.util.HashMap.newElementArray(HashMap.java:282) at java.util.HashMap.rehash(HashMap.java:686) at java.util.HashMap.rehash(HashMap.java:730) at java.util.HashMap.putImpl(HashMap.java:611) at java.util.HashMap.put(HashMap.java:605) at com.ibm.domino.xsp.module.nsf.RuntimeFileSystem.refresh(RuntimeFileSystem.java:269) at com.ibm.domino.xsp.module.nsf.NSFComponentModule.initNSFData(NSFComponentModule.java:565) at com.ibm.domino.xsp.module.nsf.NSFComponentModule.doInitModule(NSFComponentModule.java:439) at com.ibm.designer.runtime.domino.adapter.ComponentModule.initModule(ComponentModule.java:412) at com.ibm.domino.xsp.module.nsf.NSFComponentModule.initModule(NSFComponentModule.java:427) at com.ibm.domino.xsp.module.nsf.NSFService.loadModule(NSFService.java:561) at com.ibm.domino.xsp.module.nsf.NSFService.doServiceInternal(NSFService.java:439) at com.ibm.domino.xsp.module.nsf.NSFService.doService(NSFService.java:342) at com.ibm.designer.runtime.domino.adapter.LCDEnvironment.doService(LCDEnvironment.java:304) at com.ibm.designer.runtime.domino.adapter.LCDEnvironment.service(LCDEnvironment.java:261) at com.ibm.domino.xsp.bridge.http.engine.XspCmdManager.service(XspCmdManager.java:291) 2013-05-07T10:46:17.582+02:00 java.lang.OutOfMemoryError at java.util.HashMap.newElementArray(HashMap.java:282) at java.util.HashMap.rehash(HashMap.java:686) at java.util.HashMap.rehash(HashMap.java:730) at java.util.HashMap.putImpl(HashMap.java:611) at java.util.HashMap.put(HashMap.java:605) at com.ibm.domino.xsp.module.nsf.RuntimeFileSystem.refresh(RuntimeFileSystem.java:269) at com.ibm.domino.xsp.module.nsf.NSFComponentModule.initNSFData(NSFComponentModule.java:565) at com.ibm.domino.xsp.module.nsf.NSFComponentModule.doInitModule(NSFComponentModule.java:439) at com.ibm.designer.runtime.domino.adapter.ComponentModule.initModule(ComponentModule.java:412) at com.ibm.domino.xsp.module.nsf.NSFComponentModule.initModule(NSFComponentModule.java:427) at com.ibm.domino.xsp.module.nsf.NSFService.loadModule(NSFService.java:561) at com.ibm.domino.xsp.module.nsf.NSFService.doServiceInternal(NSFService.java:439) at com.ibm.domino.xsp.module.nsf.NSFService.doService(NSFService.java:342) at com.ibm.designer.runtime.domino.adapter.LCDEnvironment.doService(LCDEnvironment.java:304) at com.ibm.designer.runtime.domino.adapter.LCDEnvironment.service(LCDEnvironment.java:261) at com.ibm.domino.xsp.bridge.http.engine.XspCmdManager.service(XspCmdManager.java:291)
最佳答案
这个可能性不大,但我听说许多 Java 企业服务器都存在与类加载器、静态对象和应用程序重新部署相关的内存泄漏问题。
您能否检查是否可以通过重复清理/运行应用程序周期来重新创建 java/lang/OutOfMemoryError?
为了减少这个问题,您可以尝试将静态对象移动到应用程序范围。
关于java - XPage:Java 类实例过多导致 java/lang/OutOfMemoryError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16236164/
我正在尝试将用户提供的经纬度值与数据库中的经纬度值进行比较。如果它们在彼此半径 15 公里内,则应更改 TextView 。但我面临以下错误, 我的数据库包含值 source lat = 19.218
我在我的应用程序中使用改造来下载一些媒体文件,如视频、mp3、jpg、pdf 等。当我想下载一个 55MB 的 mp4 格式的大文件时,这是一个问题。当我想下载这个文件时,我收到这样的错误: OutO
所以我正在创建一个 Android 应用程序,这段代码引发了 "Caused by: java.lang.OutOfMemoryError: OutOfMemoryError thrown while
直到昨天,我的应用程序运行良好,但我所做的是,由于某些原因,我不得不在 Android Studio 中打开具有不同工作空间的同一个应用程序。从那时起,当我尝试运行该应用程序时,我遇到了以下异常,所以
我正在尝试构建一个应用程序,其中客户端将其屏幕发送到服务器,客户端仅在上次发送屏幕和最新捕获的屏幕之间存在差异时才发送其屏幕(以便该程序在网络)。服务器使用 JFrame 和 JLabel 来显示图像
我正在尝试使用内存映射模式在 cupy 中加载一些较大的 .npy 文件,但我不断遇到 OutOfMemoryError 。 我认为,由于它是在内存映射模式下打开的,因此此操作不应该占用太多内存,因为
我正在尝试对基于 ant 的(Netbeans RCP)项目进行分级并找到奇怪的分级行为。 我用探查器做了一些观察,得到了下一个结果。 环境配置 Gradle 1.9 Build time: 20
我有一个应用程序可以进行网络调用并检索 XML 数据。如果没有太多数据,下面的代码可以正常工作。 public class WebClient { private static final S
在我的应用程序中,我每 3 分钟刷新一次数据。如果应用程序可以工作几个小时,我会遇到这样的错误: java.lang.OutOfMemoryError at org.apache.http.util.
我在我的一个应用程序中偶尔收到 OutOfMemoryError: (Heap Size=49187KB, Allocated=41957KB)。我该怎么做才能诊断? 01-09 10:32:02
对于学校项目,我必须编写不同类型的算法。问题是,我得到了一个工作算法。但是我必须多次运行它,一段时间后它给了我以下错误: Exception in thread "main" java.lang.Ou
这个问题在这里已经有了答案: 8年前关闭。 Possible Duplicate: Recursive function causing a stack overflow 完成示例惰性序列 here
我收到 java.lang.OutOfMemoryError 错误,即使我还有足够的空闲 RAM。我进行的内存转储在 200MB 到 1GB 之间,而我的服务器有 24GB 的 RAM。我设置了 -X
我不明白为什么这段代码没有OutOfMemoryError public static void main(String[] args) { Object[] ref = new Object
我正在使用这个语句 //some code int a[][]=new int[5000000][5000000]; //some code 并使用命令运行它 java -mx512m Test 它给
今天我在玩OOM错误,我发现了一些我自己无法解释的东西。 我尝试分配一个比堆大的数组,期望 “请求的阵列大小超出 VM 限制”错误,但我得到一个“ Java 堆空间 ”错误。 根据JDK 11 doc
我有一个显示图像的简单页面。来源是 URL var img = new Image (); var source = new UriImageSource { Uri =
我有一个 Java Spring Boot 应用程序。它是一个非常大的应用程序,具有许多服务,并且可以执行大量任务。我尝试实现的新任务之一是从 Oracle DB 读取一些数据并通过 REST 将其发
我正在尝试使用流读取一个非常大的文件,因此我需要并行流而不是每行迭代...我正在尝试如下: String cont = new String(Files.readAllBytes(Paths.get(
假设我们的最大内存为 256M,为什么这段代码可以工作: public static void main(String... args) { for (int i = 0; i < 2; i++)
我是一名优秀的程序员,十分优秀!