springboot 项目使用 gradle方式构建,直接运行没有问题,但是打包后使用 java -jar
的命令运行报错:
Exception in thread "main" java.lang.reflect.InvocationTargetException
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:48)
at org.springframework.boot.loader.Launcher.launch(Launcher.java:87)
at org.springframework.boot.loader.Launcher.launch(Launcher.java:50)
at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:51)
Caused by: java.lang.NoClassDefFoundError: org/springframework/boot/SpringApplication
at com.xuexiang.xupdateservice.XUpdateServiceApplication.main(XUpdateServiceApplication.java:12)
... 8 more
Caused by: java.lang.ClassNotFoundException: org.springframework.boot.SpringApplication
at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at org.springframework.boot.loader.LaunchedURLClassLoader.loadClass(LaunchedURLClassLoader.java:94)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 9 more
异常提示说是找到类,连 main
入口都找不到。
- 原因:
springboot1.5.x
使用gradle4.x
方式打包的时候,所有的依赖jar
包都没有以打包进去,我们可以查看一下打包后的 jar 包的大小,我这里只有一百多kb,显然没有包含依赖。 - 解决方案:在build.gradle 文件根位置加入下面配置:
configurations {
custom {
it.extendsFrom implementation
}
}
bootRepackage {
customConfiguration = 'custom'
}
重新编译打包,你会发现这次打包后有几十M大小,再使用 java -jar
命令运行,一切都OK了。
分析:
springboot 1.5.x
版本使用gradle
打包的时候的 bug,在springboot 2.x
后就不存在这个问题了。
这个bug地址在springboot
的issue
中可以找到:https://github.com/spring-projects/spring-boot/issues/9143