【发布时间】:2013-09-05 00:58:00
【问题描述】:
我正在做一个项目,我将在其中拥有不同的捆绑包。举个例子,假设我有 5 个捆绑包,每个捆绑包都有一个方法名称 process。
现在,我正在使用下面的多线程代码并行调用所有这 5 个捆绑包的 process 方法。
但不知何故,每次我运行下面的多线程代码时,它总是给我内存不足的异常。但是如果我是按顺序运行的意思是,一个一个地调用进程方法,那么它不会给我任何内存不足的异常。
下面是代码-
public void callBundles(final Map<String, Object> eventData) {
// Three threads: one thread for the database writer, two threads for the plugin processors
final ExecutorService executor = Executors.newFixedThreadPool(3);
final Map<String, String> outputs = (Map<String, String>)eventData.get(Constants.EVENT_HOLDER);
for (final BundleRegistration.BundlesHolderEntry entry : BundleRegistration.getInstance()) {
executor.submit(new Runnable () {
public void run() {
try {
final Map<String, String> response = entry.getPlugin().process(outputs);
//process the response and update database.
System.out.println(response);
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
}
以下是例外,每当我在多线程代码上运行时都会遇到。
JVMDUMP006I Processing dump event "systhrow", detail "java/lang/OutOfMemoryError" - please wait.
JVMDUMP032I JVM requested Heap dump using 'S:\GitViews\Stream\goldseye\heapdump.20130904.175256.12608.0001.phd' in response to an event
JVMDUMP010I Heap dump written to S:\GitViews\Stream\goldseye\heapdump.20130904.175256.12608.0001.phd
JVMDUMP032I JVM requested Java dump using 'S:\GitViews\Stream\goldseye\javacore.20130904.175256.12608.0002.txt' in response to an event
UTE430: can't allocate buffer
UTE437: Unable to load formatStrings for j9mm
JVMDUMP010I Java dump written to S:\GitViews\Stream\goldseye\javacore.20130904.175256.12608.0002.txt
JVMDUMP032I JVM requested Snap dump using 'S:\GitViews\Stream\goldseye\Snap.20130904.175256.12608.0003.trc' in response to an event
UTE001: Error starting trace thread for "Snap Dump Thread": -1
JVMDUMP010I Snap dump written to S:\GitViews\Stream\goldseye\Snap.20130904.175256.12608.0003.trc
JVMDUMP013I Processed dump event "systhrow", detail "java/lang/OutOfMemoryError".
ERROR: Bundle BullseyeModellingFramework [1] EventDispatcher: Error during dispatch. (java.lang.OutOfMemoryError: Failed to create a thread: retVal -1073741830, errno 12)
java.lang.OutOfMemoryError: Failed to create a thread: retVal -1073741830, errno 12
JVMDUMP006I Processing dump event "systhrow", detail "java/lang/OutOfMemoryError" - please wait.
JVMDUMP032I JVM requested Heap dump using 'S:\GitViews\Stream\goldseye\heapdump.20130904.175302.12608.0004.phd' in response to an event
JVMDUMP010I Heap dump written to S:\GitViews\Stream\goldseye\heapdump.20130904.175302.12608.0004.phd
JVMDUMP032I JVM requested Java dump using 'S:\GitViews\Stream\goldseye\javacore.20130904.175302.12608.0005.txt' in response to an event
我在 Eclipse 中使用 JDK1.6.0_26 作为已安装的 JRE。
【问题讨论】:
-
我猜这就是我在上面的代码中使用的?
-
是的,我尝试在池大小为 1 的情况下这样做,我得到了同样的错误.. :(
-
这将每秒钟创建 1000 个 3 个线程(3000 个线程)的线程池...您可能需要考虑创建一个全局执行器而不是本地实例...
-
就我个人而言,我会创建一个集中处理池,所以不管是谁在调用
callBundles或从哪里调用,所有请求都进入同一个池。这使您能够根据需要管理线程池... -
你在输出映射中积累了一些东西吗?它可以长得很大,不是吗?
标签: java multithreading out-of-memory executorservice