2016-06-28 4 views
1

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

この問題を解決するためにさらに詳しい情報を提供できれば幸いです。

+0

[gf 5](http://download.oracle.com/glassfish/5.0/nightly/index.html)または[gf 4.1.1](https:///glassfish.java.net/download.html)、修正されたバグでなければなりません –

答えて

0

私はこの問題を修正して以来、長いことがありましたが、同じ問題に直面している人たち、つまり私のように同じようなことをしている人たちを助ける場合には、

問題は私のアプリケーションにありました。私のコードでは、アプリケーションは、新しいクライアント要求ごとに新しいオブジェクトを作成しました。これと同じように:それがデプロイされた場合に、サーバーの負荷がはるかに少なかったが、クライアントとして急速にメモリをより多く消費された増加し、最終的にそれは、サーバがクラッシュする原因ので、最初は

Worker workerObj = new Worker(); 

、これは問題が発生することはありませんでした。

解決策は、単一のWorkerオブジェクトを作成し、すべての要求に対してスレッドセーフな方法で再利用することでした。

関連する問題