java - ConcurrentGCThread 中 Java VM 的随机崩溃

标签 java jvm crash java-6

在不断变化的负载下运行 Internet 应用程序的 JVM 存在问题。这个问题来来去去。有一天,我们看到三台虚拟机死机,之后一两周都没有。我们还没有找到一种模式,没有发现任何可以复制或导致它的东西。在 Sun bug 数据库中搜索也没有帮助。

我们尝试了 http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=6354939 中建议的解决方法 (-XX:-CMSPermGenPrecleaningEnabled -XX:-CMSConcurrentMTEnabled) 没有帮助。它似乎只是改变了导致它的线索……或者至少让我们相信这一点。

升级到 1.6.0_13 也无济于事,向 Sun 提出的错误请求从未返回响应。

所以我的问题是,有没有人看到或知道要寻找什么?这可能与操作系统库有关吗?

编辑:操作系统是 Linux,OpenSuse 在 AMD CPU 上运行(Linux 2.6.18.8-0.1-dw #3 SMP Thu Mar 15 01:21:48 GMT 2007 x86_64 x86_64 x86_64 GNU/Linux)

#
# An unexpected error has been detected by Java Runtime Environment:
#
# SIGSEGV (0xb) at pc=0x062c75f5, pid=6667, tid=1090374560
#
# Java VM: Java HotSpot(TM) Server VM (11.2-b01 mixed mode linux-x86)
# Problematic frame:
# V [libjvm.so+0x2c75f5]
#
# If you would like to submit a bug report, please visit:
# http://java.sun.com/webapps/bugreport/crash.jsp
#

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

Current thread (0x081ddc00): ConcurrentGCThread [stack: 0x40f5c000,0x40fdd000] [id=6679]

siginfo:si_signo=SIGSEGV: si_errno=0, si_code=1 (SEGV_MAPERR), si_addr=0x0000000c

Registers:
EAX=0x00000000, EBX=0x00000008, ECX=0x0bf5e510, EDX=0x42d6dcb0
ESP=0x40fdc150, EBP=0x40fdc168, ESI=0x40fdc200, EDI=0xa19e9640
EIP=0x062c75f5, CR2=0x0000000c, EFLAGS=0x00210206

Top of Stack: (sp=0x40fdc150)
0x40fdc150: 40fdc200 71c70000 0815a748 0815a704
0x40fdc160: a19e9640 40fdc200 40fdc198 062c74cb
0x40fdc170: 40fdc200 a19e9640 0bf5e510 0bf5e510
0x40fdc180: 080ea6f0 40fdc200 00000010 a19e9640
0x40fdc190: ad38a000 40fdc200 40fdc1c8 0629efaa
0x40fdc1a0: 40fdc200 a19e9640 00000100 00000100
0x40fdc1b0: 0815ab00 40fdc200 40fdc2b8 40fdc200
0x40fdc1c0: 080ea5f0 0815a638 40fdc2b8 062c2905

Instructions: (pc=0x062c75f5)
0x062c75e5: 53 83 ec 0c 8b 7d 0c 8b 75 08 8b 47 04 8d 58 08
0x062c75f5: 8b 53 04 89 d1 c1 f9 02 85 d2 7e 6f b8 04 00 00

Stack: [0x40f5c000,0x40fdd000], sp=0x40fdc150, free space=512k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
V [libjvm.so+0x2c75f5]
V [libjvm.so+0x2c74cb]
V [libjvm.so+0x29efaa]
V [libjvm.so+0x2c2905]
V [libjvm.so+0x2bb461]
V [libjvm.so+0x2c9ef5]
V [libjvm.so+0x506929]
C [libpthread.so.0+0x52ab] 

最佳答案

我有一个非常相似的 JVM 转储。 原因是 Solaris 区域中缺少内存/交换空间。 在 64 位模式下运行相同的程序(即使用 Java 选项 -d64),错误更明显:

A fatal error has been detected by the Java Runtime Environment:

java.lang.OutOfMemoryError: requested 395856 bytes for Chunk::new. Out of swap space?

Internal Error (allocation.cpp:272), pid=10847, tid=32 Error: Chunk::new

JRE version: 6.0_23-b05 Java VM: Java HotSpot(TM) 64-Bit Server VM (19.0-b09 mixed mode solaris-sparc compressed oops) If you would like to submit a bug report, please visit: <a href="http://java.sun.com/webapps/bugreport/crash.jsp" rel="noreferrer noopener nofollow">http://java.sun.com/webapps/bugreport/crash.jsp</a>

关于java - ConcurrentGCThread 中 Java VM 的随机崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/860676/

相关文章:

java - 调用 JNI_CreateJavaVM 使程序崩溃

java - -XX :+PrintTenuringDistribution doesn't print size per age

java - 如何在 Java 中重现 EXCEPTION_STACK_OVERFLOW 错误

ios - 在 iOS 8 上点击选择框时手机间隙应用程序崩溃

java - Java 对象序列化中如何处理对另一个类的静态成员的调用?

printing - Cordova -插件打印机崩溃的Ionic2应用程序

java - TextField 大小和垂直对齐

java - Java 中的 getHostAddress() 和 getInetAddress()

java - java中ParseInt接收到的int和int的区别

java - 必需的列表参数 'state' 不存在错误