maven项目,错误: 找不到或无法加载主类 XXX
一、前言
今天在接手一个项目的时候,运行main类报了这个错错误: 找不到或无法加载主类 XXX经过好一番查证才找出了问题所在,原因是maven项目的<scope>provided</scope>导致的,现在记录一下。
二、测试代码
import org.apache.flink.table.functions.ScalarFunction; public class Test extends ScalarFunction { public static void main(String[] args) { System.out.println("test"); } }
该类继承了flink的ScalarFunction,但是maven的pom.xml文件是这么写的依赖;
<dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-table-planner_2.11</artifactId> <version>1.8.3</version> <scope>provided</scope> </dependency>
问题就出在了<scope>provided</scope>上,经查找官网得知,具有此范围的依赖项会添加到用于编译和测试的类路径中,但不会添加到运行时类路径中,交由JDK 或容器在运行时提供依赖项。因此本地运行的时候就报了找不到或无法加载主类,而放在服务器,因为容器在运行时提供依赖项,所以运行没问题。 官网地址:
三、总结
遇到问题要逐步分析,分解问题,锁定问题根源;另外要多看官网文档!