启动jar文件,报”no main manifest attribute“异常

简介: 在云服务器上部署打包好的的MQTT消息服的jar包,使用命令`nohup java -jar xxx.jar &` 启动,出现的问题

问题描述

在云服务器上部署打包好的的MQTT消息服的jar包,使用命令nohup java -jar xxx.jar &启动,出现以下问题。如下图:

4f3f50131979a6f20695cbcaf01f427b.png

## 原因分析

如上图,红色框中日志反馈的问题no main manifest attribute找不到主类;

按照自己的惯性思维,如:找不到或出现404字样,自己首先会考虑几点:

- 是不是路径没有或者发生变化自己没有及时修正;

- 是不是操作的时候误删除等情况。

知识补充

一般java打包的jar文件通常会包含清单文件(META-INF/MANIFEST.MF)该文件可以包含主类以及加载类路径等信息。

MANIFEST.MF中应用相关属性中Main-Class定义jar文件的入口类,该类必须是一个可执行的类,一旦定义了该属性即可通过启动命令执行。

查看有问题的jar包

解压jar包 "tar -xvf xx.jar" 到当前目录

异常情况:

20210616143036.png

正常情况:

20210616143714.png

排查问题

springboot在本地启动运行是正常的,打包的时候出现这种问题,所以排查pom.xml文件某些依赖或者插件出现问题,经过排查发现:

<build><resources><resource><directory>src/main/java</directory><includes><include>**/*.*</include></includes></resource><resource><directory>src/main/resources</directory><includes><include>**/*.*</include></includes></resource></resources><plugins><!--提供src结尾的jar包(提供项目源码的jar包)--><plugin><!--问题点--><groupId>org.apache.maven.plugins</groupId><artifactId>maven-source-plugin</artifactId><version>2.1.1</version></plugin></plugins><finalName>${project.finalName}</finalName></build>

项目中引入的插件是进行源文件的打包的jar文件,并非是能可执行的jar文件

重新配置打包插件

<build><resources><resource><directory>src/main/java</directory><includes><include>**/*.*</include></includes></resource><resource><directory>src/main/resources</directory><includes><include>**/*.*</include></includes></resource></resources><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins><finalName>${project.finalName}</finalName></build>

重新上传到云服务器上,使用命令执行,程序正常启动。

总结

问题是短时间解决了,但是从中反映出一个问题,对maven的知识欠缺,需要补一补才对。加油,小伙子。

目录
相关文章
|
1月前
|
Java Shell Docker
Docker启动后怎样运行jar包文件
Docker启动后怎样运行jar包文件
|
4月前
|
存储 Java 开发者
深入理解Jar文件:创建、使用和多版本控制
深入理解Jar文件:创建、使用和多版本控制
43 0
|
6月前
|
Java Maven
【异常解决】为什么会产生jar包冲突,如何排查jar包冲突?
【异常解决】为什么会产生jar包冲突,如何排查jar包冲突?
144 0
|
6月前
|
Java Maven
pom文件中引入本地jar包到maven项目
pom文件中引入本地jar包到maven项目
86 0
|
6月前
|
Java Linux
【Linux】linux下使用命令修改jar包内某一个文件中的内容并重新运行jar程序
【Linux】linux下使用命令修改jar包内某一个文件中的内容并重新运行jar程序
104 0
|
3月前
|
SQL Java 流计算
Flink SQL UDF(用户自定义函数)需要打包成JAR文件并上传到Flink集群中
【1月更文挑战第1天】【1月更文挑战第2篇】Flink SQL UDF(用户自定义函数)需要打包成JAR文件并上传到Flink集群中
83 0
|
1月前
|
Oracle 关系型数据库 Java
Flink CDC产品常见问题之Flink CDC 使用jar包启动异常如何解决
Flink CDC(Change Data Capture)是一个基于Apache Flink的实时数据变更捕获库,用于实现数据库的实时同步和变更流的处理;在本汇总中,我们组织了关于Flink CDC产品在实践中用户经常提出的问题及其解答,目的是辅助用户更好地理解和应用这一技术,优化实时数据处理流程。
|
1月前
|
存储 Java 开发工具
java-jar文件docx
java-jar文件docx
18 0
|
1月前
|
Java 应用服务中间件
解决tomcat启动报错:无法在web.xml或使用此应用程序部署的jar文件中解析绝对的url [http:java.sun.com/jsp/jstl/core]
解决tomcat启动报错:无法在web.xml或使用此应用程序部署的jar文件中解析绝对的url [http:java.sun.com/jsp/jstl/core]
107 1
|
6月前
|
Java 关系型数据库 MySQL
【Java用法】windows10系统下修改jar中的文件并重新打包成jar文件然后运行
【Java用法】windows10系统下修改jar中的文件并重新打包成jar文件然后运行
127 0