Java多线程内存不足

时间:2014-11-04 14:16:40

标签: java multithreading memory jvm

我创建了1个多线程程序,它返回内存错误。我已经设置为4000M内存,但它仍然会返回内存不足。

启动此程序的参数如下所示:

/common/packages/8.1.1/java/jdk1.6.0_38/bin/java -jar -d64 -XX:MaxPermSize=4000M -Xms4000M -Xmx4000M batchReserveNumbersReflectStatus.jar

以下是多线程源代码

ThreadPoolExecutor executor;
int maxThreadQ = 0;
maxThreadQ = 10000;

BlockingQueue queue = new ArrayBlockingQueue(maxThreadQ);
Runnable task=null;

executor = new ThreadPoolExecutor(Integer.parseInt(20),Integer.parseInt(20),2400,TimeUnit.MILLISECONDS, queue);

以下是错误的详细信息。

bash-3.2$ tail -200 hs_err_pid2321.log
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (malloc) failed to allocate 5464064 bytes for card table expansion
# Possible reasons:
#   The system is out of physical RAM or swap space
#   In 32 bit mode, the process size limit was hit
# Possible solutions:
#   Reduce memory load on the system
#   Increase physical memory or swap space
#   Check if swap backing store is full
#   Use 64 bit Java on a 64 bit OS
#   Decrease Java heap size (-Xmx/-Xms)
#   Decrease number of Java threads
#   Decrease Java thread stack sizes (-Xss)
#   Set larger code cache with -XX:ReservedCodeCacheSize=
# This output file may be truncated or incomplete.
#
#  Out of Memory Error (cardTableModRefBS.cpp:290), pid=2321, tid=2
#
# JRE version: 6.0_38-b05
# Java VM: Java HotSpot(TM) 64-Bit Server VM (20.13-b02 mixed mode solaris-sparc compressed oops)

---------------  T H R E A D  ---------------

Current thread (0x0000000100117000):  JavaThread "Unknown thread" [_thread_in_vm, id=2, stack(0xffffffff7ba00000,0xffffffff7bb00000)]

Stack: [0xffffffff7ba00000,0xffffffff7bb00000],  sp=0xffffffff7bafec80,  free space=1019k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
V  [libjvm.so+0x9b24ac]  void VMError::report_and_die()+0x75c
V  [libjvm.so+0x514844]  void report_vm_out_of_memory(const char*,int,unsigned long,const char*)+0x64
V  [libjvm.so+0x2ae6b8]  void CardTableModRefBS::resize_covered_region(MemRegion)+0x1c0
V  [libjvm.so+0x2ae348]  void CardTableExtension::resize_covered_region(MemRegion)+0xe8
V  [libjvm.so+0x2c3c44]  void PSOldGen::initialize_work(const char*,int)+0xa4
V  [libjvm.so+0x8a2920]  void PSOldGen::initialize(ReservedSpace,unsigned long,const char*,int)+0xc8
V  [libjvm.so+0x35de58]  AdjoiningGenerations::AdjoiningGenerations #Nvariant 1(ReservedSpace,unsigned long,unsigned long,unsigned long,unsigned long,unsigned long,unsigned long,unsigned long)+0x2a8
V  [libjvm.so+0x2d1d84]  int ParallelScavengeHeap::initialize()+0x4bc
V  [libjvm.so+0x96fc7c]  int Universe::initialize_heap()+0x224
V  [libjvm.so+0x2e0b90]  int universe_init()+0x118
V  [libjvm.so+0x2cea04]  int init_globals()+0xac
V  [libjvm.so+0x95bad0]  int Threads::create_vm(JavaVMInitArgs*,bool*)+0x238
V  [libjvm.so+0x2dc0f4]  JNI_CreateJavaVM+0x74
C  [java+0x2778]
[error occurred during error reporting (printing native stack), id 0xb]


---------------  P R O C E S S  ---------------

Java Threads: ( => current thread )

Other Threads:

=>0x0000000100117000 (exited) JavaThread "Unknown thread" [_thread_in_vm, id=2, stack(0xffffffff7ba00000,0xffffffff7bb00000)]

VM state:not at safepoint (not fully initialized)

VM Mutex/Monitor currently owned by a thread: None

Dynamic libraries:
0x0000000100000000      /common/packages/8.1.1/java/jdk1.6.0_38/bin/sparcv9/java
0xffffffff7f200000      /lib/64/libthread.so.1
0xffffffff7ef00000      /common/packages/8.1.1/java/jdk1.6.0_38/bin/sparcv9/../../jre/lib/sparcv9/jli/libjli.so
0xffffffff7ed00000      /lib/64/libdl.so.1
0xffffffff7e900000      /lib/64/libc.so.1
0xffffffff7f000000      /platform/SUNW,T5240/lib/sparcv9/libc_psr.so.1
0xffffffff7d800000      /common/packages/8.1.1/java/jdk1.6.0_38/jre/lib/sparcv9/server/libjvm.so
0xffffffff7d600000      /lib/64/libsocket.so.1
0xffffffff7e700000      /usr/lib/64/libsched.so.1
0xffffffff7d400000      /lib/64/libm.so.1
0xffffffff7d200000      /usr/lib/64/libCrun.so.1
0xffffffff7d000000      /lib/64/libdoor.so.1
0xffffffff7ce00000      /usr/lib/64/libdemangle.so.1
0xffffffff7cc00000      /lib/64/libkstat.so.1
0xffffffff7ca00000      /lib/64/libnsl.so.1
0xffffffff7c800000      /lib/64/libm.so.2
0xffffffff7c600000      /lib/64/libmp.so.2
0xffffffff7c400000      /lib/64/libmd.so.1
0xffffffff7c200000      /platform/SUNW,T5240/lib/sparcv9/libmd_psr.so.1
0xffffffff7c000000      /lib/64/libscf.so.1
0xffffffff7be00000      /lib/64/libuutil.so.1
0xffffffff7bc00000      /lib/64/libgen.so.1
0xffffffff7b800000      /common/packages/8.1.1/java/jdk1.6.0_38/jre/lib/sparcv9/libverify.so
0xffffffff7b600000      /common/packages/8.1.1/java/jdk1.6.0_38/jre/lib/sparcv9/libjava.so
0xffffffff7b400000      /common/packages/8.1.1/java/jdk1.6.0_38/jre/lib/sparcv9/libzip.so

VM Arguments:
jvm_args: -XX:MaxPermSize=4000M -Xms4000M -Xmx4000M
java_command: batchReserveNumbersReflectStatus.jar
Launcher Type: SUN_STANDARD

Environment Variables:
PATH=/usr/bin:
LD_LIBRARY_PATH=/common/packages/8.1.1/java/jdk1.6.0_38/jre/lib/sparcv9/server:/common/packages/8.1.1/java/jdk1.6.0_38/jre/lib/sparcv9:/common/packages/8.1.1/java/jdk1.6.0_38/jre/../lib/sparcv9
SHELL=/usr/bin/sh

Signal Handlers:
SIGSEGV: [libjvm.so+0x9b3120], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c
SIGBUS: [libjvm.so+0x9b3120], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c
SIGFPE: [libjvm.so+0x23f6b8], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c
SIGPIPE: [libjvm.so+0x23f6b8], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c
SIGXFSZ: [libjvm.so+0x23f6b8], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c
SIGILL: [libjvm.so+0x23f6b8], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c
SIGUSR1: SIG_DFL, sa_mask[0]=0x00000000, sa_flags=0x00000000
SIGUSR2: SIG_DFL, sa_mask[0]=0x00000000, sa_flags=0x00000000
SIGQUIT: SIG_IGN, sa_mask[0]=0x00000000, sa_flags=0x00000000
SIGHUP: SIG_IGN, sa_mask[0]=0x00000000, sa_flags=0x00000000
SIGINT: SIG_IGN, sa_mask[0]=0x00000000, sa_flags=0x00000000
SIGTERM: SIG_DFL, sa_mask[0]=0x00000000, sa_flags=0x00000000
SIG39: [libjvm.so+0x86c2c8], sa_mask[0]=0x00000000, sa_flags=0x00000008
SIG40: [libjvm.so+0x23f6b8], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c


---------------  S Y S T E M  ---------------

OS:                   Oracle Solaris 10 1/13 s10s_u11wos_24a SPARC
  Copyright (c) 1983, 2013, Oracle and/or its affiliates. All rights reserved.
                            Assembled 17 January 2013

uname:SunOS 5.10 Generic_150400-11 sun4v  (T2 libthread)
rlimit: STACK 8192k, CORE infinity, NOFILE 65536, AS infinity
load average:1.28 1.30 1.30

CPU:total 16 has_v8, has_v9, popc, has_vis1, has_vis2, has_blk_init, is_ultra3, is_sun4v, is_niagara, is_niagara_plus

Memory: 8k page, physical 16777216k(8945944k free)

vm_info: Java HotSpot(TM) 64-Bit Server VM (20.13-b02) for solaris-sparc JRE (1.6.0_38-b05), built on Nov 14 2012 00:50:51 by "" with Workshop 5.8

time: Tue Nov  4 14:30:01 2014
elapsed time: 0 seconds

以下是ulimit结果

bash-3.2$ ulimit -a
core file size          (blocks, -c) unlimited
data seg size           (kbytes, -d) unlimited
file size               (blocks, -f) unlimited
open files                      (-n) 256
pipe size            (512 bytes, -p) 10
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 2048
virtual memory          (kbytes, -v) unlimited

java版:

bash-3.2$ java -version -d64
java version "1.6.0_38"
Java(TM) SE Runtime Environment (build 1.6.0_38-b05)
Java HotSpot(TM) 64-Bit Server VM (build 20.13-b02, mixed mode)

我已经检查了与此相关的其他帖子,但在我的情况下仍然不起作用。有什么建议我需要做什么?

1 个答案:

答案 0 :(得分:0)

这不是java.lang.OutOfMemoryError。

此错误不同。你的原生内存耗尽了。这可能发生在Unix上,它允许你过度提交你的记忆。即你可以启动一个程序,它要求的虚拟内存比实际的可用内存要多。如果你的程序试图使用所有内存,并发现它不能如果你的交换空间不足,JVM就不知道该做什么和崩溃。

堆栈跟踪表明它是试图分配内存但失败的perm gen,但程序的其他部分可能是关键消费者。

您可能会发现减少您的perm gen和堆大小将降低您的要求并允许您的程序工作。也可能是因为创建了太多线程而导致内存不足。每个线程都分配一个堆栈空间,这也可能用完。

我建议您在应用程序崩溃后运行top并查看剩余的可用内存量。然后我会确保你的堆,perm gen和线程堆栈适合这个空间。

简而言之,你需要查看你拥有多少免费的本机内存,并尽量不要使用超过这个。