springboot 項(xiàng)目使用 gradle方式構(gòu)建,直接運(yùn)行沒有問題,但是打包后使用 java -jar 的命令運(yùn)行報錯:
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包都沒有以打包進(jìn)去,我們可以查看一下打包后的 jar 包的大小,我這里只有一百多kb,顯然沒有包含依賴。 - 解決方案:在build.gradle 文件根位置加入下面配置:
configurations {
custom {
it.extendsFrom implementation
}
}
bootRepackage {
customConfiguration = 'custom'
}
重新編譯打包,你會發(fā)現(xiàn)這次打包后有幾十M大小,再使用 java -jar 命令運(yùn)行,一切都OK了。
分析:
springboot 1.5.x版本使用gradle打包的時候的 bug,在springboot 2.x后就不存在這個問題了。
這個bug地址在springboot的issue中可以找到:https://github.com/spring-projects/spring-boot/issues/9143