动态代理远程方法调用,返回的结果不一致问题处理

在将代码部署到客户测试环境时,遇到一个异常,即在使用RemoteProxy工具类时抛出类型转换异常。尽管测试用例通过,但在实际环境中出现问题。经过深入调试,最初怀疑是AOP或线程安全问题,但最终发现是类加载器不一致导致的结果。解决方案是调整热部署依赖,解决了这一问题。
摘要由CSDN通过智能技术生成

在做客户对接的时候,客户提供了一个RemoteProxy远程代理工具类,用于获取客户提供的对接中心服务。

我写的测试用例验证通过,在布署到客户的测试环境的时候,每当跑到这个工具类的方法调用就报$Proxy can not be cast to XXX类型异常。

明明测试用例没问题,怎么上测试环境就不行了呢?

测试用例是通@Test注解的方法调用了我写的@Service内的服务再去触发RemoteProxy的方法。

测试环境则是通过页面请求@Controller提供的方法,再调用@Service及至RemoteProxy。

于是在本地配置了对应的测试环境通过断点追踪。发觉这样的情况:

@Service

public class A{

public void getClient(){

RemoteProxy.getService(); // 在这里断点,得到结果是false

}

}

public class RemoteProxy{

public static boolean getService(){

xxx

xxx

xxx

return aaa; // 在这里断点,得到的结果是true

}

}

明明断点到方法内部的最后一步,显示返回的结果是【true】。怎么在方法调用处得到的结果是【false】了呢?

由于客户提供的工具类叫RemoteProxy,固名思义是远程动态代理嘛,可能用了AOP增强,或者可能是多线程线程安全问题导致的返回结果不一致。我就钻进了这两个牛角尖里面不断的调试深挖,浪费了两天时间,甚至周六调到晚上11点,才终于放弃,让自已周日放空休息一下。

到周一上午一来,经过同事的提醒,才恍然还有可能是类加载器不一致这种情况。路子一对,瞬间就排出问题出来,的确是类加载器不一致导致的结果不一致~~~僵硬

我的项目是由于这个热布署的依赖导致,我由于偷懒直接去掉这个依赖就ok,网上应该还有保留这个依赖依然解决类加载器不一致的方案,看官们如有需要请自行百度

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值