Fix 使用JMX读取Weblogic性能信息的时候报

本文探讨了在WebLogic Server 10.3.6.0环境下通过JMX获取性能信息时出现的并发异常问题。具体表现为Cannot registertwo instances of WorkContextAccessController的错误,分析了此问题的原因在于WorkContextAccessController类实现上的多线程安全问题,并给出了修复建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如题。环境是一台Weblogic Server 10.3.6.0。在另一台机器上通过JMX来获取这台weblogic server的性能信息,比如可用堆内存之类。

由于并发量比较大,偶尔会出现异常

java.lang.IllegalStateException: Cannot register two instances of WorkContextAccessController
at weblogic.workarea.spi.WorkContextAccessController.<init>(WorkContextAccessController.java:24) ~[wlclient.jar:10.3.6.0]
at weblogic.workarea.spi.WorkContextAccessController$1.<init>(WorkContextAccessController.java:65) ~[wlclient.jar:10.3.6.0]
at weblogic.workarea.spi.WorkContextAccessController.getAccessController(WorkContextAccessController.java:65) ~[wlclient.jar:10.3.6.0]
at weblogic.workarea.spi.WorkContextAccessController.isAccessAllowed(WorkContextAccessController.java:38) ~[wlclient.jar:10.3.6.0]
at weblogic.workarea.WorkContextLocalMap.put(WorkContextLocalMap.java:50) ~[wlclient.jar:10.3.6.0]
at weblogic.workarea.WorkContextLocalMap.put(WorkContextLocalMap.java:62) ~[wlclient.jar:10.3.6.0]
at weblogic.workarea.WorkContextMapImpl.put(WorkContextMapImpl.java:52) ~[wlclient.jar:10.3.6.0]
at weblogic.management.context.JMXContextHelper$DefaultJMXContextAccessImpl.putJMXContext(JMXContextHelper.java:89) ~[wljmxclient.jar:10.3.6.0]
at weblogic.management.context.JMXContextHelper.putJMXContext(JMXContextHelper.java:36) ~[wljmxclient.jar:10.3.6.0]
at weblogic.management.remote.common.RMIConnectionWrapper.initializeJMXContext(ClientProviderBase.java:1019) ~[wljmxclient.jar:10.3.6.0]
at weblogic.management.remote.common.RMIConnectionWrapper.getAttribute(ClientProviderBase.java:764) ~[wljmxclient.jar:10.3.6.0]
at javax.management.remote.rmi.RMIConnector$RemoteMBeanServerConnection.getAttribute(RMIConnector.java:906) ~[na:1.8.0_51]

反编译一下weblogic JMX client的代码,发现这个似乎是它的一个Bug。

源代码关键点如下。这个类位于wlclient.jar中。

public abstract class WorkContextAccessController {
    
    private static WorkContextAccessController SINGLETON;


    protected WorkContextAccessController() {
        if(SINGLETON != null) {
            throw new IllegalStateException("Cannot register two instances of WorkContextAccessController");
        } else {
            SINGLETON = this;
        }
    }


    public static boolean isAccessAllowed(String var0, int var1) {
        return getAccessController().checkAccess(var0, var1);
    }


    private static WorkContextAccessController getAccessController() {
        return SINGLETON == null?new WorkContextAccessController() {
        }:SINGLETON;
    }

可以看出,在多线程同时访问isAccessAllowed的时候,在getAccessController()中可能出现并发的错误(因为对两个Thread来说SINGLETON都是null),于是调用了两次new WorkContextAccessController()。


解决方法也很简单,实现一个正确的多线程的Singleton就行了,然后覆盖wlclient.jar中的同名class。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值