maven打的包带exec包比不带的大_spark集成springboot打包执行报错class不存在

maven打包方式:

org.springframework.boot

spring-boot-maven-plugin

exec

nothing

nothing

四个spark服务器全部上传jar包了,然后

执行代码:

/data/deploy/spark/bin/spark-submit --driver-class-path /data/deploy/spark/external_jars/*.jar --class com.hydee.h3.report.SparkApplication report-spark-0.0.1-SNAPSHOT.jar

报错:

28-10-2019 15:36:31 CST ReportSpark INFO - java.lang.NoClassDefFoundError: org/springframework/boot/ApplicationRunner

28-10-2019 15:36:31 CST ReportSpark INFO - at java.lang.ClassLoader.defineClass1(Native Method)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.lang.ClassLoader.defineClass(ClassLoader.java:763)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.net.URLClassLoader.access$100(URLClassLoader.java:73)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.net.URLClassLoader$1.run(URLClassLoader.java:368)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.net.URLClassLoader$1.run(URLClassLoader.java:362)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.security.AccessController.doPrivileged(Native Method)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.net.URLClassLoader.findClass(URLClassLoader.java:361)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.lang.ClassLoader.loadClass(ClassLoader.java:424)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.lang.ClassLoader.loadClass(ClassLoader.java:357)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.lang.Class.forName0(Native Method)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.lang.Class.forName(Class.java:348)

28-10-2019 15:36:31 CST ReportSpark INFO - at org.apache.spark.util.Utils$.classForName(Utils.scala:239)

28-10-2019 15:36:31 CST ReportSpark INFO - at org.apache.spark.deploy.SparkSubmit$.org$apache$spark$deploy$SparkSubmit$$runMain(SparkSubmit.scala:851)

28-10-2019 15:36:31 CST ReportSpark INFO - at org.apache.spark.deploy.SparkSubmit$.doRunMain$1(SparkSubmit.scala:198)

28-10-2019 15:36:31 CST ReportSpark INFO - at org.apache.spark.deploy.SparkSubmit$.submit(SparkSubmit.scala:228)

28-10-2019 15:36:31 CST ReportSpark INFO - at org.apache.spark.deploy.SparkSubmit$.main(SparkSubmit.scala:137)

28-10-2019 15:36:31 CST ReportSpark INFO - at org.apache.spark.deploy.SparkSubmit.main(SparkSubmit.scala)

28-10-2019 15:36:31 CST ReportSpark INFO - Caused by: java.lang.ClassNotFoundException: org.springframework.boot.ApplicationRunner

28-10-2019 15:36:31 CST ReportSpark INFO - at java.net.URLClassLoader.findClass(URLClassLoader.java:381)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.lang.ClassLoader.loadClass(ClassLoader.java:424)

28-10-2019 15:36:31 CST ReportSpark INFO - at java.lang.ClassLoader.loadClass(ClassLoader.java:357)

28-10-2019 15:36:31 CST ReportSpark INFO - ... 19 more

Spring Boot Maven项目构建的大jar包在启动时提示找不到主类的错误,通常是因为在打包过程中主类的信息没有正确配置。要解决这个问题,可以按照以下步骤进行排查和修复: 1. 检查POM文件配置:确保在项目的`pom.xml`文件中配置了`maven-jar-plugin`,并且设置了正确的`<mainClass>`属性,该属性应指向包含`main`方法的类。例如: ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> <version>3.2.0</version> <configuration> <archive> <manifest> <addClasspath>true</addClasspath> <classpathPrefix>lib/</classpathPrefix> <mainClass>com.example.MainClass</mainClass> </manifest> </archive> </configuration> </plugin> <!-- 其他插件配置 --> </plugins> </build> ``` 请确保`<mainClass>`中的包名和类名与你的主类实际路径完全一致。 2. 检查主类的`main`方法:确保你的主类中有一个`public static void main(String[] args)`方法,并且该类的访问修饰符是`public`。 3. 使用命令行正确运行jar包:在构建完jar包后,使用如下命令来运行jar包: ```bash java -jar your-spring-boot-app.jar ``` 如果使用了Maven插件来运行jar包,确保使用正确的命令和参数,如下: ```bash mvn spring-boot:run ``` 确保在运行上述命令时,你的工作目录和jar包所在目录是正确的。 4. 确认是否有其他相关依赖未打包进jar:有时候,可能某些运行时需要的资源或库没有被打包进最终的jar中。可以通过解压jar文件检查所需的资源是否存在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值