Forum Stats

  • 3,728,251 Users
  • 2,245,583 Discussions
  • 7,853,407 Comments

Discussions

weblogic过段时间就down了,请高手帮忙看看

678055
678055 Member Posts: 3
edited January 2009 in 中间件
#
# An unexpected error has been detected by HotSpot Virtual Machine:
#
# SIGSEGV (0xb) at pc=0xfee6ef60, pid=28551, tid=767
#
# Java VM: Java HotSpot(TM) Server VM (1.5.0_11-b03 mixed mode)
# Problematic frame:
# V [libjvm.so+0x66ef60]
#

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

Current thread (0x03262a18): JavaThread "[ACTIVE] ExecuteThread: '9' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_in_vm, id=767]

siginfo:si_signo=11, si_errno=0, si_code=1, si_addr=0x00000000

Registers:
O0=0x00000000 O1=0xac47df7c O2=0xf9740b78 O3=0xfefd8000
O4=0xff02739c O5=0x00000002 O6=0xac47dbf8 O7=0xfeeaefa8
G1=0xbe6be6d8 G2=0x00000004 G3=0xf9740b79 G4=0x01018990
G5=0x00000094 G6=0x00000000 G7=0xaf4e1200 Y=0x00000000
PC=0xfee6ef60 nPC=0xfee6ef64


Top of Stack: (sp=0xac47dbf8)
0xac47dbf8: f9740b78 00000000 fea99b2c fe9c1f54
0xac47dc08: 00000000 03262ac0 00000000 f9740948
0xac47dc18: 03262a18 ac47e754 ff02188c 00000000
0xac47dc28: fefd8000 00008f0c ac47e6f0 feeaf290
0xac47dc38: 66b8eb6e f0ca28de 22d2eb23 d9ec2d52
0xac47dc48: 8d5dcb7a bed7eaaf 364516fe cf21bd0e
0xac47dc58: 550ab18d c0d1ee59 95769448 0afd226f
0xac47dc68: 50bfd767 101358b1 86c11996 317916bc

Instructions: (pc=0xfee6ef60)
0xfee6ef50: 02 40 00 26 90 10 20 00 d0 02 60 00 c2 01 20 00
0xfee6ef60: ca 02 20 00 ca 01 60 04 80 a1 40 01 12 40 00 17

Stack: [0xac400000,0xac480000), sp=0xac47dbf8, free space=502k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
V [libjvm.so+0x66ef60]
V [libjvm.so+0x6af298]
v ~ExceptionBlob
J sun.net.util.IPAddressUtil.textToNumericFormatV4(Ljava/lang/String;)[B
v ~I2CAdapter
j java.net.InetAddress.getAllByName(Ljava/lang/String;)[Ljava/net/InetAddress;+122
v ~C2IAdapter
J weblogic.net.http.HttpClient.openServer(Ljava/lang/String;I)V
v ~I2CAdapter
j weblogic.net.http.HttpClient.openServer()V+354
j weblogic.net.http.HttpClient.<init>(Ljava/net/URL;Ljava/net/Proxy;Ljavax/net/SocketFactory;II)V+34
j weblogic.net.http.HttpClient.<init>(Ljava/net/URL;Ljavax/net/SocketFactory;II)V+7
j weblogic.net.http.HttpClient.New(Ljava/net/URL;Ljavax/net/SocketFactory;ZII)Lweblogic/net/http/HttpClient;+21
j weblogic.net.http.HttpURLConnection.connect()V+39
j weblogic.net.http.HttpURLConnection.getInputStream()Ljava/io/InputStream;+136
j weblogic.rjvm.http.HTTPClientJVMConnection.connect(Ljava/net/InetAddress;I)V+218
j weblogic.rjvm.http.HTTPClientJVMConnection.createConnection(Ljava/net/InetAddress;ILweblogic/protocol/ServerChannel;)Lweblogic/rjvm/MsgAbbrevJVMConnection;+12
j weblogic.rjvm.ConnectionManager.createConnection(Lweblogic/protocol/Protocol;Ljava/net/InetAddress;ILweblogic/protocol/ServerChannel;Lweblogic/rjvm/JVMID;I)Lweblogic/rjvm/MsgAbbrevJVMConnection;+71
j weblogic.rjvm.ConnectionManager.findOrCreateConnection(Lweblogic/protocol/ServerChannel;Lweblogic/rjvm/JVMID;I)Lweblogic/rjvm/MsgAbbrevJVMConnection;+296
j weblogic.rjvm.ConnectionManager.bootstrap(Lweblogic/rjvm/JVMID;Lweblogic/protocol/ServerChannel;I)V+17
v ~C2IAdapter
J weblogic.rjvm.ConnectionManager.bootstrap(Ljava/net/InetAddress;ILweblogic/protocol/ServerChannel;I)Lweblogic/rjvm/RJVMImpl;
v ~I2CAdapter
j weblogic.rjvm.RJVMManager.findOrCreateRemoteInternal(Ljava/net/InetAddress;ILjava/lang/String;Ljava/lang/String;I)Lweblogic/rjvm/RJVM;+310
j weblogic.rjvm.RJVMManager.findOrCreate(Ljava/net/InetAddress;ILjava/lang/String;Ljava/lang/String;I)Lweblogic/rjvm/RJVM;+8
j weblogic.rjvm.RJVMFinder.findOrCreateRemoteServer(Ljava/net/InetAddress;ILjava/lang/String;I)Lweblogic/rjvm/RJVM;+15
j weblogic.rjvm.RJVMFinder.findOrCreate(ZLjava/lang/String;Lweblogic/rmi/spi/HostID;I)Lweblogic/rjvm/RJVM;+136
j weblogic.rjvm.ServerURL.findOrCreateRJVM(ZLjava/lang/String;Lweblogic/rmi/spi/HostID;I)Lweblogic/rjvm/RJVM;+9
v ~C2IAdapter
J weblogic.jndi.WLInitialContextFactoryDelegate.getInitialReference(Lweblogic/jndi/Environment;Ljava/lang/Class;)Ljava/rmi/Remote;
v ~I2CAdapter
j weblogic.jndi.Environment.getInitialReference(Ljava/lang/Class;)Ljava/rmi/Remote;+66
j weblogic.server.channels.RemoteChannelServiceImpl.registerInternal(Lweblogic/jndi/Environment;Lweblogic/rmi/extensions/DisconnectListener;)V+22
j weblogic.server.channels.RemoteChannelServiceImpl.access$300(Lweblogic/jndi/Environment;Lweblogic/rmi/extensions/DisconnectListener;)V+2
j weblogic.server.channels.RemoteChannelServiceImpl$TimerListenerImpl.timerExpired(Lweblogic/timers/Timer;)V+15
v ~C2IAdapter
J weblogic.work.SelfTuningWorkManagerImpl$WorkAdapterImpl.run()V
v ~I2CAdapter
j weblogic.work.ExecuteThread.execute(Ljava/lang/Runnable;)V+29
v ~C2IAdapter
J weblogic.work.ExecuteThread.run()V
v ~I2CAdapter
v ~StubRoutines::call_stub
V [libjvm.so+0x19b95c]
V [libjvm.so+0x2c1a24]
V [libjvm.so+0x2e1010]
V [libjvm.so+0x2dcbac]
V [libjvm.so+0x67a7e0]

Java frames: (J=compiled Java code, j=interpreted, Vv=VM code)
v ~ExceptionBlob
J sun.net.util.IPAddressUtil.textToNumericFormatV4(Ljava/lang/String;)[B
v ~I2CAdapter
j java.net.InetAddress.getAllByName(Ljava/lang/String;)[Ljava/net/InetAddress;+122
v ~C2IAdapter
J weblogic.net.http.HttpClient.openServer(Ljava/lang/String;I)V
v ~I2CAdapter
j weblogic.net.http.HttpClient.openServer()V+354
j weblogic.net.http.HttpClient.<init>(Ljava/net/URL;Ljava/net/Proxy;Ljavax/net/SocketFactory;II)V+34
j weblogic.net.http.HttpClient.<init>(Ljava/net/URL;Ljavax/net/SocketFactory;II)V+7
j weblogic.net.http.HttpClient.New(Ljava/net/URL;Ljavax/net/SocketFactory;ZII)Lweblogic/net/http/HttpClient;+21
j weblogic.net.http.HttpURLConnection.connect()V+39
j weblogic.net.http.HttpURLConnection.getInputStream()Ljava/io/InputStream;+136
j weblogic.rjvm.http.HTTPClientJVMConnection.connect(Ljava/net/InetAddress;I)V+218
j weblogic.rjvm.http.HTTPClientJVMConnection.createConnection(Ljava/net/InetAddress;ILweblogic/protocol/ServerChannel;)Lweblogic/rjvm/MsgAbbrevJVMConnection;+12
j weblogic.rjvm.ConnectionManager.createConnection(Lweblogic/protocol/Protocol;Ljava/net/InetAddress;ILweblogic/protocol/ServerChannel;Lweblogic/rjvm/JVMID;I)Lweblogic/rjvm/MsgAbbrevJVMConnection;+71
j weblogic.rjvm.ConnectionManager.findOrCreateConnection(Lweblogic/protocol/ServerChannel;Lweblogic/rjvm/JVMID;I)Lweblogic/rjvm/MsgAbbrevJVMConnection;+296
j weblogic.rjvm.ConnectionManager.bootstrap(Lweblogic/rjvm/JVMID;Lweblogic/protocol/ServerChannel;I)V+17
v ~C2IAdapter
J weblogic.rjvm.ConnectionManager.bootstrap(Ljava/net/InetAddress;ILweblogic/protocol/ServerChannel;I)Lweblogic/rjvm/RJVMImpl;
v ~I2CAdapter
j weblogic.rjvm.RJVMManager.findOrCreateRemoteInternal(Ljava/net/InetAddress;ILjava/lang/String;Ljava/lang/String;I)Lweblogic/rjvm/RJVM;+310
j weblogic.rjvm.RJVMManager.findOrCreate(Ljava/net/InetAddress;ILjava/lang/String;Ljava/lang/String;I)Lweblogic/rjvm/RJVM;+8
j weblogic.rjvm.RJVMFinder.findOrCreateRemoteServer(Ljava/net/InetAddress;ILjava/lang/String;I)Lweblogic/rjvm/RJVM;+15
j weblogic.rjvm.RJVMFinder.findOrCreate(ZLjava/lang/String;Lweblogic/rmi/spi/HostID;I)Lweblogic/rjvm/RJVM;+136
j weblogic.rjvm.ServerURL.findOrCreateRJVM(ZLjava/lang/String;Lweblogic/rmi/spi/HostID;I)Lweblogic/rjvm/RJVM;+9
v ~C2IAdapter
J weblogic.jndi.WLInitialContextFactoryDelegate.getInitialReference(Lweblogic/jndi/Environment;Ljava/lang/Class;)Ljava/rmi/Remote;
v ~I2CAdapter
j weblogic.jndi.Environment.getInitialReference(Ljava/lang/Class;)Ljava/rmi/Remote;+66
j weblogic.server.channels.RemoteChannelServiceImpl.registerInternal(Lweblogic/jndi/Environment;Lweblogic/rmi/extensions/DisconnectListener;)V+22
j weblogic.server.channels.RemoteChannelServiceImpl.access$300(Lweblogic/jndi/Environment;Lweblogic/rmi/extensions/DisconnectListener;)V+2
j weblogic.server.channels.RemoteChannelServiceImpl$TimerListenerImpl.timerExpired(Lweblogic/timers/Timer;)V+15
v ~C2IAdapter
J weblogic.work.SelfTuningWorkManagerImpl$WorkAdapterImpl.run()V
v ~I2CAdapter
j weblogic.work.ExecuteThread.execute(Ljava/lang/Runnable;)V+29
v ~C2IAdapter
J weblogic.work.ExecuteThread.run()V
v ~I2CAdapter
v ~StubRoutines::call_stub

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

Java Threads: ( => current thread )
0x029211b8 JavaThread "MultiThreadedHttpConnectionManager cleanup" daemon [_thread_blocked, id=1132]
0x0336f128 JavaThread "[STANDBY] ExecuteThread: '13' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=771]
0x01dc13b0 JavaThread "[ACTIVE] ExecuteThread: '12' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=770]
0x013beb90 JavaThread "[STANDBY] ExecuteThread: '11' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=769]
0x02c1f348 JavaThread "[STANDBY] ExecuteThread: '10' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=768]
=>0x03262a18 JavaThread "[ACTIVE] ExecuteThread: '9' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_in_vm, id=767]
0x033bf678 JavaThread "[ACTIVE] ExecuteThread: '8' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_in_native, id=766]
0x034a16a8 JavaThread "[ACTIVE] ExecuteThread: '7' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_in_native, id=685]
0x0321a398 JavaThread "[STANDBY] ExecuteThread: '6' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=92]
0x0240cce8 JavaThread "weblogic.i18n.logging.MessageResetScheduler" daemon [_thread_blocked, id=75]
0x02a79f18 JavaThread "Thread-23" daemon [_thread_blocked, id=73]
0x0113d2d8 JavaThread "Thread-22" daemon [_thread_blocked, id=72]
0x027c83b0 JavaThread "[ACTIVE] ExecuteThread: '5' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=69]
0x0073c580 JavaThread "[STANDBY] ExecuteThread: '4' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=66]
0x02af03b8 JavaThread "[STANDBY] ExecuteThread: '3' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=65]
0x0322c528 JavaThread "Java2D Disposer" daemon [_thread_blocked, id=64]
0x0041dae0 JavaThread "DynamicListenThread[Default[2]]" daemon [_thread_in_native, id=63]
0x0041d918 JavaThread "DynamicSSLListenThread[DefaultSecure[2]]" daemon [_thread_in_native, id=62]
0x03344c50 JavaThread "DynamicListenThread[Default[3]]" daemon [_thread_in_native, id=61]
0x03344688 JavaThread "DynamicListenThread[Default]" daemon [_thread_in_native, id=60]
0x038c5a28 JavaThread "DynamicSSLListenThread[DefaultSecure[3]]" daemon [_thread_in_native, id=59]
0x038c5860 JavaThread "DynamicListenThread[Default[1]]" daemon [_thread_in_native, id=58]
0x01d695b8 JavaThread "DynamicSSLListenThread[DefaultSecure]" daemon [_thread_in_native, id=57]
0x01d693f0 JavaThread "DynamicSSLListenThread[DefaultSecure[1]]" daemon [_thread_in_native, id=56]
0x01d4c9a0 JavaThread "weblogic.GCMonitor" daemon [_thread_blocked, id=55]
0x03237ab0 JavaThread "Timer-3" daemon [_thread_blocked, id=54]
0x004dd650 JavaThread "Thread-16" daemon [_thread_blocked, id=53]
0x004dd9f0 JavaThread "DefaultQuartzScheduler_QuartzSchedulerThread" [_thread_blocked, id=52]
0x004dd828 JavaThread "DefaultQuartzScheduler_Worker-9" [_thread_blocked, id=51]
0x02980038 JavaThread "DefaultQuartzScheduler_Worker-8" [_thread_blocked, id=50]
0x0278bca8 JavaThread "DefaultQuartzScheduler_Worker-7" [_thread_blocked, id=49]
0x01d41b10 JavaThread "DefaultQuartzScheduler_Worker-6" [_thread_blocked, id=48]
0x01d41948 JavaThread "DefaultQuartzScheduler_Worker-5" [_thread_blocked, id=47]
0x010b0b70 JavaThread "DefaultQuartzScheduler_Worker-3" [_thread_blocked, id=45]
0x00a0c730 JavaThread "DefaultQuartzScheduler_Worker-2" [_thread_blocked, id=44]
0x02e40e68 JavaThread "DefaultQuartzScheduler_Worker-1" [_thread_blocked, id=43]
0x014a3b50 JavaThread "DefaultQuartzScheduler_Worker-0" [_thread_blocked, id=42]
0x03275628 JavaThread "Thread-15" daemon [_thread_blocked, id=41]
0x02e41e70 JavaThread "Thread-14" daemon [_thread_blocked, id=40]
0x0321fe98 JavaThread "RMI LeaseChecker" daemon [_thread_blocked, id=37]
0x0321fbd8 JavaThread "RMI RenewClean-[172.16.3.41:61369]" daemon [_thread_blocked, id=35]
0x00883698 JavaThread "GC Daemon" daemon [_thread_blocked, id=33]
0x03744008 JavaThread "RMI Reaper" [_thread_blocked, id=32]
0x02342b30 JavaThread "RMI TCP Accept-0" daemon [_thread_in_native, id=31]
0x02354150 JavaThread "Adaptor:name=html,port=8082" daemon [_thread_in_native, id=30]
0x017b92d0 JavaThread "RMI TCP Accept-10341" daemon [_thread_in_native, id=29]
0x02307378 JavaThread "Timer-2" daemon [_thread_blocked, id=28]
0x0130c608 JavaThread "Dispatcher-Thread-12" daemon [_thread_blocked, id=27]
0x031fa260 JavaThread "[STANDBY] ExecuteThread: '2' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=26]
0x00478c98 JavaThread "Thread-11" daemon [_thread_blocked, id=25]
0x0264ad60 JavaThread "DoSManager" daemon [_thread_blocked, id=24]
0x022fc758 JavaThread "VDE Transaction Processor Thread" daemon [_thread_blocked, id=22]
0x022d43a0 JavaThread "[ACTIVE] ExecuteThread: '1' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_blocked, id=21]
0x00883888 JavaThread "Thread-7" daemon [_thread_blocked, id=20]
0x022d46a8 JavaThread "weblogic.timers.TimerThread" daemon [_thread_blocked, id=19]
0x00887890 JavaThread "weblogic.time.TimeEventGenerator" daemon [_thread_blocked, id=18]
0x022e5398 JavaThread "[ACTIVE] ExecuteThread: '0' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon [_thread_in_native, id=17]
0x003c25b0 JavaThread "Timer-1" daemon [_thread_blocked, id=16]
0x01cb3e70 JavaThread "Timer-0" daemon [_thread_blocked, id=15]
0x00165530 JavaThread "Low Memory Detector" daemon [_thread_blocked, id=13]
0x001643d8 JavaThread "CompilerThread1" daemon [_thread_blocked, id=12]
0x00163560 JavaThread "CompilerThread0" daemon [_thread_blocked, id=11]
0x001626e8 JavaThread "AdapterThread" daemon [_thread_blocked, id=10]
0x001619b0 JavaThread "Signal Dispatcher" daemon [_thread_blocked, id=9]
0x0014e348 JavaThread "Finalizer" daemon [_thread_blocked, id=8]
0x0014de08 JavaThread "Reference Handler" daemon [_thread_blocked, id=7]
0x00038240 JavaThread "main" [_thread_blocked, id=1]

Other Threads:
0x0014bd28 VMThread [id=6]
0x001671c8 WatcherThread [id=14]

VM state:not at safepoint (normal execution)

VM Mutex/Monitor currently owned by a thread: None

Heap
PSYoungGen total 91264K, used 840K [0xe7c00000, 0xee000000, 0xf8800000)
eden space 89344K, 0% used [0xe7c00000,0xe7cd2260,0xed340000)
from space 1920K, 0% used [0xedc40000,0xedc40000,0xede20000)
to space 1792K, 0% used [0xede40000,0xede40000,0xee000000)
PSOldGen total 548864K, used 82463K [0xc6400000, 0xe7c00000, 0xe7c00000)
object space 548864K, 15% used [0xc6400000,0xcb487ea8,0xe7c00000)
PSPermGen total 86016K, used 84387K [0xbe400000, 0xc3800000, 0xc6400000)
object space 86016K, 98% used [0xbe400000,0xc3668e40,0xc3800000)

Dynamic libraries:
0x00010000 /export/home/mw/beaclw/jdk150_11/bin/java
0xff3a0000 /lib/libthread.so.1
0xff370000 /lib/libdl.so.1
0xff200000 /lib/libc.so.1
0xff390000 /platform/SUNW,Sun-Fire-V890/lib/libc_psr.so.1
0xfe800000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/server/libjvm.so
0xff330000 /lib/libsocket.so.1
0xff350000 /usr/lib/libsched.so.1
0xff300000 /usr/lib/libCrun.so.1
0xff1e0000 /lib/libm.so.1
0xff100000 /lib/libnsl.so.1
0xfe700000 /lib/libm.so.2
0xff0d0000 /lib/libscf.so.1
0xff1c0000 /lib/libdoor.so.1
0xff0b0000 /lib/libuutil.so.1
0xff090000 /lib/libgen.so.1
0xff060000 /lib/libmd.so.1
0xfe7e0000 /platform/SUNW,Sun-Fire-V890/lib/libmd_psr.so.1
0xfe6e0000 /lib/libmp.so.2
0xfe6a0000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/native_threads/libhpi.so
0xfe640000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libverify.so
0xfe600000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libjava.so
0xfe5e0000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libzip.so
0xfe4c0000 /usr/lib/locale/zh_CN.GBK/zh_CN.GBK.so.3
0xfe5a0000 /usr/lib/locale/zh.GBK/methods_zh.GBK.so.3
0xb65d0000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libnet.so
0xb6560000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libj2pkcs11.so
0xb6530000 /usr/lib/libpkcs11.so
0xb6510000 /usr/lib/libcryptoutil.so.1
0xb6420000 /usr/lib/security/pkcs11_softtoken_extra.so
0xb60b0000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libnio.so
0xb5ba0000 /lib/librt.so.1
0xb58e0000 /lib/libaio.so.1
0xb58c0000 /usr/lib/libsendfile.so.1
0xb57e0000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libmanagement.so
0xb4fe0000 /export/home/mw/beaclw/wlserver_10.0/server/native/solaris/sparc/libstackdump.so
0xb4fc0000 /export/home/mw/beaclw/wlserver_10.0/server/native/solaris/sparc/libwlfileio2.so
0xaf5c0000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/librmi.so
0xacc80000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libawt.so
0xacb00000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libmlib_image.so
0xaf3c0000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/headless/libmawt.so
0xaca00000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libfontmanager.so
0xad390000 /export/home/mw/beaclw/jdk150_11/jre/lib/sparc/libjpeg.so

VM Arguments:
jvm_args: -Dsn=perbankEnd -Xms800m -Xmx800m -XX:MaxPermSize=128m -da -Dplatform.home=/export/home/mw/beaclw/wlserver_10.0 -Dwls.home=/export/home/mw/beaclw/wlserver_10.0/server -Dwli.home=/export/home/mw/beaclw/wlserver_10.0/integration -Dweblogic.management.discover=false -Dweblogic.management.server=http://172.16.3.41:7090 -Dwlw.iterativeDev=false -Dwlw.testConsole=false -Dwlw.logErrorsToConsole= -Dweblogic.ext.dirs=/export/home/mw/beaclw/patch_wls1001/profiles/default/sysext_manifest_classpath -Djava.awt.headless=true -Dfile.encoding=GBK -Ddefault.client.encoding=GBK -Duser.language=zh -Duser.region=CN -Dweblogic.management.username=weblogic_per -Dweblogic.management.password=weblogic_9ER -Dweblogic.Name=perbank -Djava.security.policy=/export/home/mw/beaclw/wlserver_10.0/server/lib/weblogic.policy
java_command: weblogic.Server
Launcher Type: SUN_STANDARD

Environment Variables:
JAVA_HOME=/export/home/mw/beaclw/jdk150_11
CLASSPATH=/export/home/ap/ebankapp/perbank/WEB-INF/lib/commons-logging.jar:/export/home/mw/beaclw/patch_wls1001/profiles/default/sys_manifest_classpath/weblogic_patch.jar:/export/home/mw/beaclw/jdk150_11/lib/tools.jar:/export/home/mw/beaclw/wlserver_10.0/server/lib/weblogic_sp.jar:/export/home/mw/beaclw/wlserver_10.0/server/lib/weblogic.jar:/export/home/mw/beaclw/modules/features/weblogic.server.modules_10.0.1.0.jar:/export/home/mw/beaclw/modules/features/com.bea.cie.common-plugin.launch_2.1.2.0.jar:/export/home/mw/beaclw/wlserver_10.0/server/lib/webservices.jar:/export/home/mw/beaclw/modules/org.apache.ant_1.6.5/lib/ant-all.jar:/export/home/mw/beaclw/modules/net.sf.antcontrib_1.0b2.0/lib/ant-contrib.jar::/export/home/mw/beaclw/wlserver_10.0/common/eval/pointbase/lib/pbclient51.jar:/export/home/mw/beaclw/wlserver_10.0/server/lib/xqrl.jar::
PATH=/export/home/mw/beaclw/wlserver_10.0/server/bin:/export/home/mw/beaclw/modules/org.apache.ant_1.6.5/bin:/export/home/mw/beaclw/jdk150_11/jre/bin:/export/home/mw/beaclw/jdk150_11/bin:/usr/bin:/export/home/mw/beaclw/wlserver_10.0/common/bin:./:/export/home/ap/ebankapp/domains/per_domain/bin:/export/home/ap/ebankapp/domains/per_domain
LD_LIBRARY_PATH=/export/home/mw/beaclw/jdk150_11/jre/lib/sparc/server:/export/home/mw/beaclw/jdk150_11/jre/lib/sparc:/export/home/mw/beaclw/jdk150_11/jre/../lib/sparc::/export/home/mw/beaclw/wlserver_10.0/server/native/solaris/sparc:/export/home/mw/beaclw/wlserver_10.0/server/native/solaris/sparc/oci920_8
SHELL=/usr/bin/ksh

Signal Handlers:
SIGSEGV: [libjvm.so+0x709bb4], sa_mask[0]=0xffbffeff, sa_flags=0x00000004
SIGBUS: [libjvm.so+0x709bb4], sa_mask[0]=0xffbffeff, sa_flags=0x00000004
SIGFPE: [libjvm.so+0x274474], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c
SIGPIPE: [libjvm.so+0x274474], sa_mask[0]=0xffbffeff, sa_flags=0x0000000c
SIGILL: [libjvm.so+0x274474], 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
SIGHUP: SIG_IGN, sa_mask[0]=0x00000000, sa_flags=0x00000000
SIGINT: SIG_IGN, sa_mask[0]=0x00000000, sa_flags=0x00000000
SIGQUIT: [libjvm.so+0x67bb74], sa_mask[0]=0xffbffeff, sa_flags=0x00000004
SIGTERM: [libjvm.so+0x67bb74], sa_mask[0]=0xffbffeff, sa_flags=0x00000004


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

OS: Solaris 10 5/08 s10s_u5wos_10 SPARC
Copyright 2008 Sun Microsystems, Inc. All Rights Reserved.
Use is subject to license terms.
Assembled 24 March 2008

uname:SunOS 5.10 Generic_127127-11 sun4u (T2 libthread)
rlimit: STACK 8192k, CORE infinity, NOFILE 65536, AS infinity
load average:0.34 0.26 0.25

CPU:total 4 has_v8, has_v9, has_vis1, has_vis2, is_ultra3

Memory: 8k page, physical 8388608k(1089264k free)

vm_info: Java HotSpot(TM) Server VM (1.5.0_11-b03) for solaris-sparc, built on Dec 15 2006 01:18:11 by unknown with unknown Workshop:0x550

Answers

  • 678055
    678055 Member Posts: 3
    自顶一下,着急哦
  • 678055
    678055 Member Posts: 3
    各位高手,请帮忙看看:
    我看到:
    PSYoungGen total 91264K, used 840K [0xe7c00000, 0xee000000, 0xf8800000)
    eden space 89344K, 0% used [0xe7c00000,0xe7cd2260,0xed340000)
    from space 1920K, 0% used [0xedc40000,0xedc40000,0xede20000)
    to space 1792K, 0% used [0xede40000,0xede40000,0xee000000)
    PSOldGen total 548864K, used 82463K [0xc6400000, 0xe7c00000, 0xe7c00000)
    object space 548864K, 15% used [0xc6400000,0xcb487ea8,0xe7c00000)
    PSPermGen total 86016K, used 84387K [0xbe400000, 0xc3800000, 0xc6400000)
    object space 86016K, 98% used [0xbe400000,0xc3668e40,0xc3800000)

    永生代内存快用完了,98%了。但是我设置的最大是128M啊,怎么总共只有86M呢?

    另外,不太清楚,永生代为什么会用完呢?有内存泄露?

    另外,我看到:
    ~ExceptionBlob
    J sun.net.util.IPAddressUtil.textToNumericFormatV4(Ljava/lang/String;)
    是从这个异常开始的,在应用中,有用到httpconnection,难到是这个有问题??

    请各位高手帮忙看看,谢谢。
  • 678327
    678327 Member Posts: 11
    帮顶。。。
  • 656992
    656992 Member Posts: 34
    能把log发上来么?
    导致MaxPermSize不够用原因可能是你的应用程序本身类太多,你的类有多少这个可以通过你的应用大小确定(不包括非程序文件基本上是class+jsp所占磁盘空间)这个值只是估计值,再有如果程序使用了动态声明创建类那么也会占用MaxPermSize空间,而且使用了动态声明创建类会随着你的用户数增加导致占用MaxPermSize越多,建议你从以下几个方面检查你的系统:
    1.检查你的应用总共类的大小是否超出了你设定的MaxPermSize值
    2.了解你的应用是否使用动态声明创建类的技术
    解决上面两种情况可以加大MaxPermSize值,看看还会不会出现OutofMemory问题
    如果你怀疑有内存泄露可以参考以下方法查找:
    探查内存不足/内存泄漏问题

    问题描述

    内存不足 (OOM) - 由于 java 堆或本地内存中的内存耗尽,应用程序显示“内存不足”错误。

    内存泄漏 - java 堆或本地内存的持续内存增长,最终将导致内存不足状态。调试内存泄漏状态的技术与调试内存不足状态的技术相同。

    故障排除
    请注意,并非下面所有任务都需要完成。有些问题仅通过执行几项任务就可以解决。

    快速链接:

    Java 堆、本地内存和进程大小
    进程地址空间和物理内存之间的差异
    为什么会发生 OOM 问题,JVM 在这种情况下如何处理?
    排除故障的步骤
    确定是 Java OOM 还是本地 OOM
    Java OOM
    本地 OOM
    Jrockit 特定特性
    参考文献
    Java 堆、本地内存和进程大小

    Java 堆 - 这是 JVM 用来分配 java 对象的内存。java 堆内存的最大值用 java 命令行中的 .Xmx 标志来指定。如果未指定最大的堆大小,那么该极限值由 JVM 根据诸如计算机中的物理内存量和该时刻的可用空闲内存量这类因素来决定。始终建议您指定最大的 java 堆值。

    本地内存 - 这是 JVM 用于其内部操作的内存。JVM 将使用的本地内存堆数量取决于生成的代码量、创建的线程、GC 期间用于保存 java 对象信息的内存,以及在代码生成、优化等过程中使用的临时空间。

    如果有一个第三方本地模块,那么它也可能使用本地内存。例如,本地 JDBC 驱动程序将分配本地内存。

    最大本地内存量受到任何特定操作系统上的虚拟进程大小限制的约束,也受到用 .Xmx 标志指定用于 java 堆的内存量的限制。例如,如果应用程序能分配总计为 3 GB 的内存量,并且最大 java 堆的大小为 1 GB,那么本地内存量的最大值可能在 2 GB 左右。
    进程大小 - 进程大小将是 java 堆、本地内存与加载的可执行文件和库所占用内存的总和。在 32 位操作系统上,进程的虚拟地址空间最大可达到 4 GB。从这 4 GB 内存中,操作系统内核为自己保留一部分内存(通常为 1 - 2 GB)。剩余内存可用于应用程序。

    Windows缺省情况下,2 GB 可用于应用程序,剩余 2 GB 保留供内核使用。但是,在 Windows 的一些变化版本中,有一个 /3GB 开关可用于改变该分配比率,使应用程序能够获得 3 GB。有关 /3GB 开关的详细信息,可以在以下网址中找到:
    http://msdn.microsoft.com/library/default.asp?url=/library/en-us/ddtools/hh/ddtools/bootini_1fcj.asp

    RH Linux AS 2.1 - 3 GB 可用于应用程序。

    对于其它操作系统,请参考操作系统文档了解有关配置。

    返回页首

    进程地址空间和物理内存之间的差异

    每个进程都获得其自有的地址空间。在 32 位操作系统中,此地址空间范围为 0 到 4 GB。此范围与计算机的可用随机存取内存 (RAM) 或交换空间无关。计算机中的可用物理内存总量是该计算机上的可用 RAM 和交换空间之和。所有运行的进程共享这些物理内存。

    进程内的存储地址是虚拟地址。内核将此虚拟地址映射到物理地址上。物理地址指向物理内存中的某个位置。在任一给定时间,计算机中运行进程所使用的全部虚拟内存的总和不能超过该计算机上可用物理内存的总量。

    返回页首

    为什么会发生 OOM 问题,JVM 在这种情况下如何处理?

    java 堆中的内存不足
    如果 JVM 不能在 java 堆中获得更多内存来分配更多 java 对象,将会抛出 java 内存不足 (java OOM) 错误。如果 java 堆充满了活动对象,并且 JVM 无法再扩展 java 堆,那么它将不能分配更多 java 对象。

    在这种情况下,JVM 让应用程序决定在抛出 java.lang.OutOfMemoryError 后该执行什么操作。例如,应用程序可以处理此错误,并决定以安全方式自行关闭或决定忽略此错误。如果应用程序不处理此错误,那么抛出此错误的线程将退出(如果您进行 java Thread Dump,那么将看不到该线程)。

    在使用 Weblogic Server 的情况下,如果此错误是由某个执行线程抛出的,则会处理此错误并将其记录在日志中。如果连续抛出此错误,那么核心运行状况监视器线程将关闭 Weblogic Server。

    本地堆中的内存不足
    如果 JVM 无法获得更多本地内存,它将抛出本地内存不足(本地 OOM)错误。当进程到达操作系统的进程大小限值,或者当计算机用完 RAM 和交换空间时,通常会发生这种情况。

    当发生这种情况时,JVM 处理本地 OOM 状态,记录说明它已用完本地内存或无法获得内存的消息,然后退出。如果 JVM 或加载的任何其它模块(如 libc 或第三方模块)不处理这个本地 OOM 状态,那么操作系统将给 JVM 发送命令 JVM 退出的 sigabort 信号。通常情况下,JVM 收到 sigabort 信号时将会生成一个核心文件。

    返回页首

    排除故障的步骤

    确定是 Java OOM 还是本地 OOM:
    如果 stdout/stderr 消息说明这是一个 java.lang.OutOfMemoryError,那么这就是 Java OOM
    如果 stdout/stderr 消息说明无法获得内存,那么这就是本地 OOM
    请注意,上述消息仅发送到 stdout 或 stderr 中,而不发送到应用程序特定的日志文件(如 weblogic.log)

    返回页首

    对于 Java OOM:

    收集和分析 verbose gc 输出
    在 java 命令行中添加“-verbosegc”标志。这样将会把 GC 活动信息打印到 stdout/stderr。将 stdout/stderr 重定向到一个文件。运行应用程序,直到该问题重现。
    确保 JVM 在抛出 java OOM 之前完成下列任务
    完整 GC 运行:
    执行一次完整 GC 运行,并且删除了所有不可及对象以及虚可及、弱可及、软可及对象,并回收了那些空间。有关不同级别的对象可及性的详细信息,可以在以下网址中可找到:
    http://java.sun.com/developer/technicalArticles/ALT/RefObj

    您可以检查是否在发出 OOM 消息之前执行了完整 GC 运行。当完成一次完整 GC 运行时,将会打印类似如下消息(格式取决于 JVM - 请查看 JVM 帮助信息以了解有关格式)

    [memory ] 7.160: GC 131072K->130052K (131072K) in 1057.359 ms

    以上输出的格式如下(备注:在此模式下将全部使用相同的格式):

    [memory ] <start>: GC <before>K-><after>K (<heap>K), <total> ms
    [memory ] <start> - start time of collection (seconds since jvm start)
    [memory ] <before> - memory used by objects before collection (KB)
    [memory ] <after> - memory used by objects after collection (KB)
    [memory ] <heap> - size of heap after collection (KB)
    [memory ] <total> - total time of collection (milliseconds)

    但是,没有办法断定是否使用 verbose 消息删除了软/弱/虚可及的对象。如果您怀疑在抛出 OOM 时这些对象仍然存在,请与 JVM 供应商联系。

    如果垃圾回收算法是一种按代回收算法(对于 Jrockit 为 gencopy 或 gencon,对于其它 JDK 则是缺省算法),您也将看到类似如下的 verbose 输出:
    [memory ] 2.414: Nursery GC 31000K->20760K (75776K), 0.469 ms

    以上是 nursery GC(即 young GC)周期,它将把活动对象从 nursery(或 young 空间)提升到 old 空间。这个周期对我们的分析不重要。有关按代回收算法的详细信息,可以在 JVM 文档中找到。

    如果在 java OOM 之前未发生 GC 周期,那么这是一个 JVM 错误。

    完全压缩:
    确保 JVM 执行了适当的压缩工作,并且内存并未成碎片(否则会阻止分配大对象并触发 java OOM 错误)。

    Java 对象要求内存是连续的。如果可用空闲内存是一些碎片,那么 JVM 将无法分配大对象,因为它可能无法放入任何可用空闲内存块中。在这种情况下,JVM 将执行一次完全压缩,以便形成更多连续的空闲内存来容纳大对象。

    压缩工作包括在 java 堆内存中将对象从一个位置移动到另一个位置,以及更新对这些对象的引用以指向新位置。除非确有必要,否则 JVM 不会压缩所有对象。这是为了减少 GC 周期的暂停时间。

    我们可以通过分析 verbose gc 消息来检查 java OOM 是否由碎片引起。如果您看到类似如下的输出(在此无论是否有可用的空闲 java 堆都会抛出 OOM),那么这就是由碎片引起的。

    [memory ] 8.162: GC 73043K->72989K (131072K) in 12.938 ms
    [memory ] 8.172: GC 72989K->72905K (131072K) in 12.000 ms
    [memory ] 8.182: GC 72905K->72580K (131072K) in 13.509 ms
    java.lang.OutOfMemoryError

    在上述情况中您可以看到,所指定的最大堆内存是 128MB,并且当实际内存使用量仅为 72580K 时,JVM 抛出 OOM。堆使用量仅为 55%。因此在这种情况下,碎片影响是:即使还有 45% 的空闲堆,内存也会抛出 OOM。这是一个 JVM 错误或缺陷。您应当与 JVM 供应商联系。

    如果 JVM 一切都正常(上一步中提到的所有操作),那么此 java OOM 可能是应用程序的问题。应用程序可能在不断泄漏一些 java 内存,而这可能导致出现上述问题。或者,应用程序使用更多的活动对象,因此它需要更多 java 堆内存。在应用程序中可以检查以下方面:
    应用程序中的缓存功能 - 如果应用程序在内存中缓存 java 对象,则应确保此缓存并没有不断增大。对缓存中的对象数应有一个限值。我们可以尝试减少此限值,来观察其是否降低 java 堆使用量。
    Java 软引用也可用于数据缓存,当 JVM 用完 java 堆时,可以保证删除软可及对象。

    长期活动对象 - 如果应用程序中有长期活动对象,则可以尝试尽可能减少这些对象的存在期。例如,调整 HTTP 会话超时值将有助于更快地回收空闲会话对象。

    内存泄漏 - 内存泄漏的一个例子是在应用服务器中使用数据库连接池。当使用连接池时,必须在 finally 块中显式关闭 JDBC 语句和结果集对象。这是因为,当从池中调用连接对象上的 close() 时,只是简单地把连接返回池中以供重用,并没有实际关闭连接和关联的语句/结果集对象。

    增加 java 堆 - 如果可能的话,我们也可尝试增加 java 堆,以观察是否能解决问题。


    如果上述建议都不适用于该应用程序,那么,我们需要使用一个基于 JVMPI(JVM 事件探查器接口)的事件探查器(如 Jprobe 或 OptimizeIt)来找出哪些对象正在占用 java 堆。事件探查器还提供 java 代码中正在创建这些对象的位置的详细信息。本文档并不介绍每个事件探查器的详细信息。可以参考事件探查器文档来了解如何用事件探查器设置和启动应用程序。一般而言,基于 JVMPI 的事件探查器需要较高的系统开销,并会大大降低应用程序的性能。因此,在生产环境中使用这些事件探查器并不可取。
    http://www.borland.com/optimizeit
    http://www.quest.com/jprobe
    返回页首

    对于本地 OOM 问题:

    收集下列信息:
    .verbosegc 输出,通过它可监视 java 堆使用量。这样将有助于了解此应用程序的 java 内存要求。
    应当注意,指定的最大堆内存量(在 java 命令行中使用 Xmx 标志)与应用程序的实际 java 堆使用量无关,其在 JVM 启动时被保留,并且此保留内存不能用于其它任何用途。

    在使用 Jrockit 时,使用 -verbose 来代替 -verbosegc,因为这可以提供 codegen 信息以及 GC 信息。
    定期记录进程虚拟内存大小,从启动应用程序时起直到 JVM 用完本地内存。这样将有助于了解此进程是否确实达到该操作系统的大小限值。
    在 Windows 环境下,使用下列步骤来监视虚拟进程大小:
    在“开始” -> “运行”对话框中,输入“perfmon”并单击“确定”。
    在弹出的“性能”窗口中,单击“+”按钮(图表上部)。
    在显示的对话框中选择下列选项:
    性能对象:进程(不是缺省的处理器)
    从列表中选择计数器:虚拟字节数
    从列表中选择实例:选择 JVM (java) 实例
    单击“添加”,然后单击“关闭”
    在 Unix 或 Linux 环境下,对于一个给定 PID,可以使用以下命令来查找虚拟内存大小 - ps -p <PID> -o vsz。

    在 Linux 环境下,单个 JVM 实例内的每个 java 线程都显示为一个独立的进程。如果我们获得根 java 进程的 PID,那么这就足够了。可以使用 ps 命令的 .forest 选项来找到根 java 进程。例如,ps lU <user> --forest 将提供一个由指定用户启动的所有进程的 ASCII 树图。您可以从该树图中找到根 java。

    计算机中的内存可用性
    如果计算机没有足够的 RAM 和交换空间,则操作系统将不能为此进程提供更多内存,这样也会导致内存不足。请确保 RAM 与磁盘中的交换空间之和足以满足该计算机中正在运行的所有进程的需要。

    调整 java 堆
    如果 java 堆使用量完全在最大堆范围内,则减小 java 最大堆将为 JVM 提供更多的本地内存。这不是一个解决办法,而是一个可尝试的变通方法。由于操作系统限制进程大小,我们需要在 java 堆和本地堆之间寻求一个平衡。
    JVM 的本地内存使用量
    在加载了所有类并调用了方法(代码生成结束)后,JVM 的本地内存用量预计将会几乎达到稳定。对于大多数应用程序而言,这通常发生在最初几小时内。此后,JVM 可能会因加载运行时类型、生成优化代码等处理而仅使用少量本地内存。

    为了缩小问题的范围,可尝试禁用运行时优化,并检查这是否会产生任何效果。

    在使用 Jrockit 时,可使用 -Xnoopt 标志来禁用运行时优化。

    在使用 SUN hotspot JVM 时,-Xint 标志将强迫 JVM 在解释模式中运行(不生成代码)。
    如果在整个运行过程中,本地内存使用量继续不断增加,那么这可能是本地代码中的内存泄漏。

    第三方本地模块或应用程序中的 JNI 代码
    检查您是否在使用类似数据库驱动程序的任何第三方本地模块。这些本地模块也可以分配本地内存,泄漏可能从这些模块中发生。为了缩小问题的范围,应尝试在没有这些第三方模块的情况下重现问题。例如,可以使用纯 java 驱动程序来代替本地数据库驱动程序。

    检查应用程序是否使用一些 JNI 代码。这也可能造成本地内存泄漏,如果可能的话,您可以尝试在没有 JNI 代码的情况下运行应用程序。

    如果在执行上述步骤后还不能找到本地内存泄漏的根源,那么您需要与 JVM 供应商合作来获得一个特殊的编译版本,它可以跟踪本地内存分配调用,并可提供有关泄漏的更多信息。

    Jrockit 特定特性
    Jrockit 81SP1 和更高版本支持 JRA 记录(Java 运行时间分析器)。这对于收集 JVM 运行时的信息很有用,将提供应用程序的有关信息,例如,正在运行的 GC 数、软/弱/虚引用的数目、热方法,等等。如果 JVM 出现性能问题或挂起问题,那么用几分钟进行记录和分析数据就会很有用。有关详细信息,可以在 Jrockit 文档中找到。
    http://e-docs.bea.com/wljrockit/docs142/userguide/jra.html
This discussion has been closed.