`

weblogic JMX 中遇到的问题

 
阅读更多
通过JMX操作来监控weblogic jdbcpool实例如下
package weblogic;
import java.util.*;
import javax.management.*;
import weblogic.management.*;
import weblogic.management.configuration.*;
import weblogic.management.runtime.ServerRuntimeMBean;
import weblogic.management.runtime.JDBCConnectionPoolRuntimeMBean;

public class TestJMX {

/**取得当前weblogic server 的jdbcconnectionPool
* @param args
*/

public MBeanHome localHome;
public MBeanHome adminHome;
public Stack stack;
public static String SERVER_NAME="myserver";
public Stack find()
{
stack=new Stack();
String url="t3://130.30.15.44:8080";
//其中t3 是protocol
localHome = (MBeanHome)Helper.getMBeanHome("weblogic","weblogic",url,SERVER_NAME);
adminHome = (MBeanHome)Helper.getAdminMBeanHome("weblogic","weblogic",url);
Set set1 =adminHome.getMBeansByType("JDBCTxDataSource");
Set set2 =adminHome.getMBeansByType("JDBCDataSource");
Iterator it1 = set1.iterator();
while(it1.hasNext()){
JDBCTxDataSourceMBean dm1 = (JDBCTxDataSourceMBean)it1.next();
System.out.println("%%%%%%%%%%%"+dm1.getJNDIName());
stack.add(dm1.getJNDIName());
}

Iterator it2 = set2.iterator();
while(it2.hasNext()){
JDBCDataSourceMBean dm2 = (JDBCDataSourceMBean)it2.next();
System.out.println("%%%%%%%%%%%"+dm2.getJNDIName());
stack.add(dm2.getJNDIName());
}

return stack;

}

public static void main(String[] args ) {
TestJMX test=new TestJMX();
test.find();
}
}
我访问的是weblogic 8 我的jdk 是1.6
附:请导入weblogic.jar编译出错如下
<2008-5-8 上午10时28分11秒 CST> <Error> <RJVM> <BEA-000503> <Incoming message header or abbreviation processing failed
java.io.InvalidClassException: javax.management.ObjectName; local class incompatible: stream classdesc serialVersionUID = -5467795090068647408, local class serialVersionUID = 1081892073854801359
java.io.InvalidClassException: javax.management.ObjectName; local class incompatible: stream classdesc serialVersionUID = -5467795090068647408, local class serialVersionUID = 1081892073854801359
at java.io.ObjectStreamClass.initNonProxy(ObjectStreamClass.java:562)
at java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1583)
at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1496)
at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1316)
at java.io.ObjectInputStream.readObject(ObjectInputStream.java:351)
at weblogic.rjvm.ClassTableEntry.readExternal(ClassTableEntry.java:33)
at java.io.ObjectInputStream.readExternalData(ObjectInputStream.java:1792)
at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1751)
at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1329)
at java.io.ObjectInputStream.readObject(ObjectInputStream.java:351)
at weblogic.rjvm.InboundMsgAbbrev.readObject(InboundMsgAbbrev.java:65)
at weblogic.rjvm.InboundMsgAbbrev.read(InboundMsgAbbrev.java:37)
at weblogic.rjvm.MsgAbbrevJVMConnection.readMsgAbbrevs(MsgAbbrevJVMConnection.java:212)
at weblogic.rjvm.MsgAbbrevInputStream.readMessageContext(MsgAbbrevInputStream.java:237)
at weblogic.rjvm.ConnectionManager.dispatch(ConnectionManager.java:744)
at weblogic.rjvm.t3.T3JVMConnection.dispatch(T3JVMConnection.java:782)
at weblogic.socket.SocketMuxer.readReadySocketOnce(SocketMuxer.java:705)
at weblogic.socket.SocketMuxer.readReadySocket(SocketMuxer.java:641)
at weblogic.socket.JavaSocketMuxer.processSockets(JavaSocketMuxer.java:282)
at weblogic.socket.SocketReaderRequest.execute(SocketReaderRequest.java:32)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:224)
at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:183)
>
Exception in thread "main" weblogic.rjvm.PeerGoneException: ; nested exception is:
java.rmi.UnmarshalException: Incoming message header or abbreviation processing failed ; nested exception is:
java.io.InvalidClassException: javax.management.ObjectName; local class incompatible: stream classdesc serialVersionUID = -5467795090068647408, local class serialVersionUID = 1081892073854801359
at weblogic.rjvm.BasicOutboundRequest.sendReceive(BasicOutboundRequest.java:108)
at weblogic.rmi.internal.BasicRemoteRef.invoke(BasicRemoteRef.java:164)
at weblogic.management.internal.AdminMBeanHomeImpl_815_WLStub.getMBeansByType(Unknown Source)
at weblogic.TestJMX.find(TestJMX.java:26)
at weblogic.TestJMX.main(TestJMX.java:48)
Caused by: java.rmi.UnmarshalException: Incoming message header or abbreviation processing failed ; nested exception is:
java.io.InvalidClassException: javax.management.ObjectName; local class incompatible: stream classdesc serialVersionUID = -5467795090068647408, local class serialVersionUID = 1081892073854801359
at weblogic.rjvm.ConnectionManager.dispatch(ConnectionManager.java:765)
at weblogic.rjvm.t3.T3JVMConnection.dispatch(T3JVMConnection.java:782)
at weblogic.socket.SocketMuxer.readReadySocketOnce(SocketMuxer.java:705)
at weblogic.socket.SocketMuxer.readReadySocket(SocketMuxer.java:641)
at weblogic.socket.JavaSocketMuxer.processSockets(JavaSocketMuxer.java:282)
at weblogic.socket.SocketReaderRequest.execute(SocketReaderRequest.java:32)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:224)
at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:183)
Caused by: java.io.InvalidClassException: javax.management.ObjectName; local class incompatible: stream classdesc serialVersionUID = -5467795090068647408, local class serialVersionUID = 1081892073854801359
at java.io.ObjectStreamClass.initNonProxy(ObjectStreamClass.java:562)
at java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1583)
at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1496)
at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1316)
at java.io.ObjectInputStream.readObject(ObjectInputStream.java:351)
at weblogic.rjvm.ClassTableEntry.readExternal(ClassTableEntry.java:33)
at java.io.ObjectInputStream.readExternalData(ObjectInputStream.java:1792)
at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1751)
at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1329)
at java.io.ObjectInputStream.readObject(ObjectInputStream.java:351)
at weblogic.rjvm.InboundMsgAbbrev.readObject(InboundMsgAbbrev.java:65)
at weblogic.rjvm.InboundMsgAbbrev.read(InboundMsgAbbrev.java:37)
at weblogic.rjvm.MsgAbbrevJVMConnection.readMsgAbbrevs(MsgAbbrevJVMConnection.java:212)
at weblogic.rjvm.MsgAbbrevInputStream.readMessageContext(MsgAbbrevInputStream.java:237)
at weblogic.rjvm.ConnectionManager.dispatch(ConnectionManager.java:744)
... 7 more
--------------- nested within: ------------------
weblogic.rmi.extensions.RemoteRuntimeException: Unexpected Exception - with nested exception:
[weblogic.rjvm.PeerGoneException: ; nested exception is:
java.rmi.UnmarshalException: Incoming message header or abbreviation processing failed ; nested exception is:
java.io.InvalidClassException: javax.management.ObjectName; local class incompatible: stream classdesc serialVersionUID = -5467795090068647408, local class serialVersionUID = 1081892073854801359]
at weblogic.management.internal.AdminMBeanHomeImpl_815_WLStub.getMBeansByType(Unknown Source)
at weblogic.TestJMX.find(TestJMX.java:26)
at weblogic.TestJMX.main(TestJMX.java:48)
分享到:
评论
2 楼 yy8093 2015-06-04  
只能在JDK1.4下监控WebLogic Server 8.x
首先,要访问WebLogic Server 8.x的MBeans,必须是在JDK1.4环境下 ,如果是JDK5+环境下会很麻烦, 原因如下 :
----------------------------------------------------------------------------------------------------------------------
因为1.4的时代JDK还没有提供javax.management包,所 以WebLogic 8.x的weblogic.jar中自己包含了javax.management包,而JDK5中也有javax.management包,JVM运行时 会优先加载JDK5中javax.management包里的类,而weblogic.jar和JDK5中javax.management的实现是不一 样的,因此会产生错误。而且weblogic8.x支持JMX 1.0,而JDK5支持JMX1.2 。
----------------------------------------------------------------------------------------------------------------------
网上有人说通过System.setProperty("jmx.serial.form", "1.0");这样的设置可以解决问题,经试验根本不行。
1 楼 beyondsanli 2008-05-08  
有人说是:
这并不是程序有问题,只是他们不兼容,找了好久,没有合适的解决方法,只好改用Weblogic server9,希望好用吧!
欢迎大家赐教!

相关推荐

    LR上配置监控WEBLOGIC

    - 在实际使用过程中,有时可能会遇到权限问题。例如,在安装WebLogic时,默认情况下没有直接启用WebLogic的安全认证,这可能会影响后续的监控工作。 - 解决方法是:首先确保WebLogic服务器的控制台地址(如`...

    Eclipse下Weblogic配置详解

    同时,提供的文档如`weblogic.doc`和`EclipseWebLogic1.1.1.pdf`将提供更深入的指导,包括可能遇到的问题解决方案和最佳实践。 记住,配置过程可能会因Eclipse版本和WebLogic版本的不同而略有差异,所以根据实际...

    AIX下的Weblogic安装

    在AIX环境下,遇到问题时,查看WebLogic的日志文件(如`&lt;domain_home&gt;/logs/&lt;server_name&gt;.log`)和AIX系统的系统日志(如`/var/adm/messages`)可以帮助定位问题。 以上就是在AIX系统中安装、配置和启动WebLogic...

    weblogic自学全套教程

    【WebLogic自学全套教程】 WebLogic是Oracle公司提供的一个企业级Java应用服务器,它支持Java EE(Enterprise ...而《weblogic修改端口.txt》则提供了具体的端口修改方法,帮助你在实际环境中解决可能遇到的问题。

    WebLogic问题排除概览

    WebLogic问题排除概览主要介绍如何诊断和解决WebLogic服务器中的各类问题,同时介绍了Oracle公司提供的OracleGuardian工具,该工具是专门用于诊断WebLogic服务器的工具,可以在多个阶段帮助用户发现并解决问题。...

    weblogic 常见问题 TROUBLE_SHOOTING

    本资料主要针对WebLogic Server的常见问题及其解决方法进行讨论,帮助用户在遇到问题时能够快速定位并解决。 首先,我们来看看一些有用的资源: 1. WebLogic Server的安装介质可以从BEA官方站点下载,包括在线...

    weblogic 使用的问题

    然而,像任何复杂系统一样,WebLogic在使用过程中可能会遇到各种问题。这篇博客(https://fly533.iteye.com/blog/662036)可能详细记录了某个开发者或管理员在使用WebLogic时遇到的挑战以及解决方法,虽然描述为空,...

    WebLogic Support Patterns

    在运行复杂的分布式应用程序时,可能会遇到各种问题和挑战,这时就需要掌握WebLogic Server的支持模式和故障诊断最佳实践。 1. **日志分析与监控** - WebLogic Server的日志文件是诊断问题的关键资源,包括`server...

    weblogic 错误信息详解

    WebLogic提供了一些内置的诊断工具,如JMX Console、WLST(WebLogic Scripting Tool)和JConsole,可以帮助管理员监控服务器状态,收集诊断信息,甚至执行远程操作来调试问题。 7. **社区支持** 当遇到难以解决的...

    weblogic9使用手册

    当遇到问题时,日志文件和诊断信息是关键。手册会介绍如何查看和解析WebLogic Server的日志,以及如何使用诊断框架(JFR,Java Flight Recorder)和诊断工具(JDK Mission Control)来定位和解决问题。 八、集群...

    weblogic部署

    当遇到问题时,首先检查WebLogic的日志文件,它通常包含了错误信息和调试信息。同时,可以调整服务器的JVM参数以优化性能,例如增加堆内存大小、调整垃圾回收策略等。 10. **集群与高可用性**: 对于高可用性和...

    Oracle WebLogic 11g 安装部署文档

    Oracle提供了一些工具,如WebLogic Diagnostic Framework (WLDF) 和JMX,来监控服务器性能和诊断问题。通过监控内存、CPU使用率、线程状态等指标,可以优化服务器配置以达到最佳性能。 总结,Oracle WebLogic 11g的...

    企业级IT运维宝典之WebLogic实战

    当遇到问题时,能够有效地分析WebLogic的日志文件、诊断数据和JVM堆转储至关重要。学习如何利用JConsole、VisualVM等工具进行故障排查,能迅速定位并解决问题,减少系统宕机时间。 七、WebLogic与数据库集成 ...

    WebLogic错误 java.lang.AssertionError: Registered more than one

    在WebLogic Server 9.2至10.0版本中,用户可能会遇到一个特定的错误,即“java.lang.AssertionError: Registered more than one instance with the same objectName”。这个错误主要表现为服务器启动后,在Admin ...

    在weblogic 部署出现的 错误

    - **使用诊断工具**:WebLogic提供了一些诊断工具,如JMX控制台、WLST(WebLogic Scripting Tool)等,可以帮助排查问题。 - **修改配置**:根据错误信息,调整相应的配置文件,如`weblogic-application.xml`或`...

    weblogic session丢失

    问题描述中提到的"NULL"可能意味着在实际运行过程中,WebLogic服务器突然清空或无法识别用户的session,导致用户在操作过程中失去已有的状态信息。这可能是由于多种原因引起的,包括配置问题、服务器资源限制、网络...

    weblogic日常维护手册.doc

    - **javacore和heapdump文件**:当WebLogic遇到严重问题时,可能会生成这些文件,它们提供了内存和线程的快照,用于分析和解决问题。 4. **配置文件config.xml** - **概述**:config.xml是WebLogic Server域配置...

    weblogic管理员手册

    6. **监控与诊断**:了解如何使用WebLogic Server内置的管理控制台(Admin Console)、JMX(Java Management Extensions)和日志系统来监控服务器状态和诊断问题。 7. **性能优化**:手册会提供性能调优的指导,...

    WebLogic部署应用程序(图解)

    通过阅读提供的“WebLogic.doc”文档,你可以更深入地了解这些概念和具体的操作步骤,从而在实际部署过程中避免遇到问题。无论你是新手还是经验丰富的开发者,理解WebLogic的部署流程都将有助于提升你的工作效率。

    Weblogic管理员手册 for windows [PDF]

    当遇到问题时,手册提供了排查步骤和故障解决策略,包括日志分析、使用Diagnostic Framework收集诊断信息、使用JConsole等工具进行远程诊断。 九、备份与恢复策略 定期备份和恢复策略是防止数据丢失和灾难恢复的...

Global site tag (gtag.js) - Google Analytics