GlassFish 4.1のWebソケット用にWebアプリケーションを使用していますが、最近までこの問題が2回発生しました。それは私のアプリケーションが予想通りにクラッシュする原因となり、私は正確な理由を正確に特定できませんでした。 - メモリを食いつぶすGlassFish 4.1 FilterChain実行中のOutOfMemoryError
GRIZZLY0013: Exception during FilterChain execution
java.lang.OutOfMemoryError: Java heap space
at java.util.Arrays.copyOf(Arrays.java:3181)
at java.util.ArrayList.grow(ArrayList.java:261)
at java.util.ArrayList.ensureExplicitCapacity(ArrayList.java:235)
at java.util.ArrayList.ensureCapacityInternal(ArrayList.java:227)
at java.util.ArrayList.add(ArrayList.java:458)
at org.glassfish.grizzly.filterchain.FilterChainContext.addCompletionListener(FilterChainContext.java:930)
at org.glassfish.grizzly.utils.IdleTimeoutFilter.queueAction(IdleTimeoutFilter.java:249)
at org.glassfish.grizzly.utils.IdleTimeoutFilter.handleRead(IdleTimeoutFilter.java:167)
at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:284)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:201)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:133)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:112)
at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:561)
at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:112)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:117)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:56)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:137)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:565)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:545)
at java.lang.Thread.run(Thread.java:745)
トレースから、FilterChainContext.addCompletionListenerは、ArrayListのサイズが大幅に増加させる、あまりにも頻繁に呼び出さなっていることと思われる:ここで私は取得エラートレースです。サーバーがこのタイプのリスナーを何度も追加する原因になりますか?サーバーに要求が多すぎますか?これはGlassFishバグですか、これは単純にヒープサイズの増加に関係していますか?
現時点では、フラグ-Xmxで示されるヒープサイズが512MBから2GBに増加しました。また、-XXを介してGC のパラレルコレクタを強制します。+ UseParallelGC。
この問題を解決するためにさらに詳しい情報を提供できれば幸いです。
[gf 5](http://download.oracle.com/glassfish/5.0/nightly/index.html)または[gf 4.1.1](https:///glassfish.java.net/download.html)、修正されたバグでなければなりません –