我有问题从shell命令运行jar,因为我继续“无法找到或加载主类错误”
将jar文件放入我的服务器后。我执行以下命令
java -jar mapr.jar
但我得到一个错误说 - 无法找到或加载主类
以下是我的项目结构 -
mapreduce (projectname)
--src/main/java
--mapreduce (packagename)
--Map.java
--ZipProcessor.java (main Class)
和我的POM.xml文件 -
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.project.hadoop</groupId>
<artifactId>mapreduce</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>MapReduce</name>
<dependencies>
<dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-common</artifactId>
<version>2.5.0</version>
</dependency>
<dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-mapreduce-client-common</artifactId>
<version>2.5.0</version>
</dependency>
</dependencies>
<build>
<finalName>mapr</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.4</version>
<configuration>
<archive>
<manifest>
<mainClass>ZipProcessor</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
</plugins>
</build>
</project>
我使用下面的插件解决了我的问题
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<mainClass>
com.application.ZipProcessor
</mainClass>
</manifest>
</archive>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
</configuration>
</execution>
</executions>
</plugin>
<manifest>
<mainClass>ZipProcessor</mainClass>
</manifest>
应该完成上面的主类声明,包括包名和类名。
如果您的包名是com.test.processor而您的类名是App,那么主类的上述声明应如下所示:
<manifest>
<mainClass>com.test.processor.App</mainClass>
</manifest>
希望这可以解决您的问题。