jvm加载jar包顺序

        这是关于一次jar包冲突的错误,由于进行项目迁移,需要更换服务器。在所有都准备好以后,程序正常启动,但是在访问一个接口的时候,出现方法未找到的错误,一般这种错误都是jar包冲突导致的,但是想不通的是原来的服务器就没问题,换到新服务器就冲突了?经过一番苦苦寻找,终于找到相互冲突的jar包,然后去掉多余的jar包,重启,接口正常运行。

        虽然问题解决了,但是这个问题是怎么出现的还是不清楚,然后各种查资料,终于明白了问题所在。原来是jvm在加载jar的时候是根据linux系统inode号顺序来加载的。

        下次再遇到类似的问题,可以直接用 ls -i 命令查看文件的inode号,然后看看两个服务器之间的顺序有哪些差别,这样就会更容易找到问题所在了。

这里面讲到了jvm是如何加载jar包的:https://www.cnblogs.com/saaav/p/7716179.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java虚拟机(JVM)中,当运行Java应用程序时,JVM会按照特定的顺序加载jar文件。这个加载顺序是由类加载器决定的。类加载器负责加载类文件并将其转化为可执行代码。如果在不同的jar文件或类路径中存在相同的类文件,JVM将按照以下顺序加载jar文件: 1. 启动类路径(bootstrap classpath): 这是JVM加载类文件的最高优先级。它包含了JVM运行所需的核心类库,如Java API类库。启动类路径可以通过"-Xbootclasspath"选项指定。 2. 扩展类路径(extension classpath): 这是JVM加载扩展类库的优先级较低的路径。扩展类库包含了在运行Java应用程序时所需的额外的类库。扩展类路径可以通过"-Djava.ext.dirs"系统属性指定。 3. 应用程序类路径(application classpath): 这是JVM加载应用程序类文件的路径。它是自定义类和jar文件的主要位置。应用程序类路径可以通过"-classpath"选项或者设置CLASSPATH环境变量来指定。 当JVM加载类时,它会按照上述顺序从不同的jar文件中查找所需的类文件。如果在某个jar文件中找到了需要的类文件,JVM加载并使用它。如果在多个jar文件中存在相同的类文件,JVM将按照加载顺序找到的第一个类文件,并将其加载为类对象。 总之,JVMjar加载顺序是启动类路径、扩展类路径、应用程序类路径。这个顺序确保了JVM可以正确加载并使用所需的类文件,在Java应用程序中提供了灵活的jar文件管理方式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值