大伙记住,Java 程序运行后,把jar删除,后果很严重!
问题现象
最近线上就发生此情况,莫名其妙出现
Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: com.lolo.jsis.common.SpecialCarEnum
查看源代码,类存在呀! what and why?
查看服务器,发现工程的jar 不见了,才想起原来因规避漏洞,把jar转移位置了。
因此,基本上确诊问题所在,就是jvm 根据启动路径找不到jar, 即就无法加载需要使用的类了…
问题分析
比如你的jar包有三个class,一个主函数的类文件:Main.class,两个业务的:Service1.class,Service2.class,如果你的程序启动后,假设启动时并未用到两个业务类,当用户进行操作,当操作到第一步时会用到Service1.class中的代码,操作第二步时会调用Service2.class中的业务代码。以下业务代码简称S1,S2
这里分情况:
- 当用户还没进行任何操作时,即S1、S2还没被使用,当然也不会触发类加载,此时如果删除jar包,会发现java进程依然存在,但是如果用户此时去操作,就会报错,因为S1和S2还没被加载到jvm中,就被用户删了。
- 如果用户已经操作了第一步和第二步,再删除jar,则不影响。
总结
删除前要看所有的class是否都被加载到内存中,如果没有被加载到内存,但是后面某一步操作却触发了类加载就会报错!