给出一个案例。
场景: 同事写了一个消息队列,接收消息后通过线程池分配线程执行service,在service中引用了一个工具类,调用第三方提供的webservice服务并做一些逻辑处理。工具类中使用main方法在本地测试成功。
问题: 项目打包并放入线上环境后,debug远程调试发现在执行service中调用工具类的语句时报错,无论怎样都不进入try/catch,反而是由FutureTask抛出了异常。直接把语句放入watch中执行(eclipse作为调试工具),发现报错ClassNoDefException。
分析: ClassNoDefException一般是由于程序编译期间正常,但在运行期间加载到JVM时由于找不到对应的类而报错。因此我怀疑工具类中某个引用的jar找不到导致,接着发现webservice生成的类中在远程debug时有大量的类找不到,最终发现果然是因为打包后的线上环境缺少调用webservice所必需的的axis相关jar包。
中途尝试过:
1. 替换工具类文件名称 (怀疑类名与项目/系统中其它文件重名)
2. 修改工具类和webservice服务生成的java文件所在包(怀疑因为service无法访问工具类)