浅谈在JAR中同名类冲突问题

楔子

这段时间再给客户部署服务的时候,发现有一个服务在公司通过了所有测试,但是却在客户现场的生产环境上报出了一个诡异的问题。由于对出问题的那段代码不熟悉,所有前后折腾了2个小时才定位出来,原来是服务依赖的两个JAR包中都同时出现了一个同名类(该类的完全限定名一样),并且这两个类中都包含了同一个方法。在公司环境中执行的是正确的那个方法,而在客户现场执行的是错误的方法。这就导致了在公司没有问题的服务部署在现场就出现了问题。

正文

一、同名类产生的原因

当同名类(完全限定名)在自己编写的工程中肯定不会出现,但是这无法保证在服务所依赖的JAR中不会出现。在多人协作时,如果每个人在自己负责的服务中都需要引用一段公共代码,同时又把它抽象到一个类的一个方法中,并且大家还采用了代码拷贝的方式进行维护。此时如果有1个人对这段代码做了定制化的修改,但没有修改方法或类的名称。这个时候如果有场景需要将多个服务合并打包发布的时候,这个定制化的类就变成了一颗定时炸弹。由于同一个类加载器对于同名类只会加载一次,那么一旦JVM的选取策略发生了变化,那么就会爆发不可控的风险。

二、JAR包加载的顺序

问题产生的原因其实是简单的,但是又是什么原因造成同名类在不同的环境下被选择了不同的版本?

由于同名类是在不同JAR出现的,所以这个问题就转化成了JAR的加载顺序是由什么因素导致的

  1. 类加载器级别

    JVM的类加载其实是一个树形结构,而JVM在加载类的时候采用的是双亲代理模式,层级越高的类加

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值