在pom.xml中指定主类

为什么要在pom.xml中指定主类?


从图中可以看到两个jar。kafkastormtest1-0.0.1-SNAPSHOT.jar时运行包,是你使用mvn打包之后你的工程下的代码以及jar包,kafkastormtest1-0.0.1-SNAPSHOT-jar-with-dependencies.jar,这个是依赖包,包含你的源码和相应的包,以及依赖的包。

如果在使用kafkastormtest1-0.0.1-SNAPSHOT.jar向集群提交topology的时候出现以下错误:




这种报错的解决办法:

在你的项目的根目录下找到pom.xml。在这个配置文件中加上如下内容:

 <plugin>
       <groupId>org.apache.maven.plugins</groupId>
       <artifactId>maven-shade-plugin</artifactId>
        <executions>
           <execution>
                <phase>package</phase>
                      <goals>
                         <goal>shade</goal>
                             </goals>
                           <configuration>
                             <transformers>
                                <transformer
                                   implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                 <mainClass>kafkastorm.kafkastorm.TopicMsgTopology</mainClass>
                                  </transformer>
                                </transformers>
                          </configuration>
             </execution>
          </executions>
 </plugin>

注意:一定要将上面的内容放入<pligins>上述内容</plugins>。


这样就可以保证直接提交kafkastormtest1-0.0.1-SNAPSHOT.jar能够成功提交到集群中。


<?xml version="1.0" encoding="UTF-8"?> <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.aleks</groupId> <artifactId>demo</artifactId> <version>1.0.0</version> <packaging>pom</packaging> <modules> <module>deploy</module> <module>module</module> </modules> <parent> <!-- 必须降级Spring Boot到2.x版本 --> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.7.18</version> <!-- Java 8兼容的最新稳定版 --> <relativePath/> </parent> <properties> <java.version>1.8</java.version> <!-- 修改版本号 --> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.7.18</version> <!-- 同步版本号 --> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter</artifactId> <version>5.8.2</version> <!-- Java 8兼容版本 --> <scope>test</scope> </dependency> </dependencies> </dependencyManagement> </project><?xml version="1.0" encoding="UTF-8"?> <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> <parent> <groupId>com.aleks</groupId> <artifactId>demo</artifactId> <version>1.0.0</version> </parent> <artifactId>deploy</artifactId> <packaging>pom</packaging> <modules> <module>main-deploy</module> </modules> </project><?xml version="1.0" encoding="UTF-8"?> <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> <parent> <groupId>com.aleks</groupId> <artifactId>deploy</artifactId> <version>1.0.0</version> </parent> <artifactId>main-deploy</artifactId> <packaging>jar</packaging> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.7.18</version> <!-- 同步插件版本 --> <configuration> <mainClass>com.aleks.MainApplication</mainClass> </configuration> </plugin> </plugins> </build> </project>
最新发布
03-13
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值