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

问题描述

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

原因分析

如上图,红色框中日志反馈的问题no main manifest attribute找不到主类;
按照自己的惯性思维,如:找不到或出现404字样,自己首先会考虑几点:

  • 是不是路径没有或者发生变化自己没有及时修正;
  • 是不是操作的时候误删除等情况。

知识补充

一般java打包的jar文件通常会包含清单文件(META-INF/MANIFEST.MF)该文件可以包含主类以及加载类路径等信息。
MANIFEST.MF中应用相关属性中Main-Class定义jar文件的入口类,该类必须是一个可执行的类,一旦定义了该属性即可通过启动命令执行。

查看有问题的jar包

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

异常情况:

正常情况:

排查问题

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的知识欠缺,需要补一补才对。加油,小伙子。

  • 9
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
当在Docker中启动Jeecg的jar包时,出现"no main manifest attribute"错误。这是因为运行的jar包缺少了主清单属性。 要解决这个问题,有几种方法可供尝试: 1. 确认jar包的结构:首先,使用压缩软件(如WinRAR)打开jar包,检查是否存在META-INF/MANIFEST.MF文件,以及该文件中是否包含"Main-Class"属性。如果不存在或属性值不正确,我们需要手动添加或修复这个属性。 2. 执行正确的打包操作:在构建Jeecg项目时,确保使用正确的打包命令来生成可执行的jar包。一种常见的构建方式是使用Maven构建工具,并使用"Maven Package"命令来生成可执行的jar包。这样,会自动将主类信息添加到MANIFEST.MF文件中。 3. 定义 MANIFEST.MF 文件:如果在MANIFEST.MF文件中没有找到"Main-Class"属性,可以手动创建一个新的MANIFEST.MF文件,并在其中定义该属性。在项目的根目录下,创建META-INF文件夹,并在该文件夹中创建MANIFEST.MF文件,在其中添加以下内容: ``` Main-Class: com.example.MainClassName ``` 将"com.example.MainClassName"替换为Jeecg项目中的主类名。 4. 使用Dockerfile进行打包:在Docker镜像构建过程中,可以在Dockerfile中添加相关命令,以确保正确地构建可运行的jar包。例如,在Dockerfile中添加以下命令来将Jeecg项目打包成可执行的jar文件: ``` COPY target/jeecg.jar app.jar ENTRYPOINT ["java","-jar","/app.jar"] ``` 这将把项目的jar包复制到Docker镜像中,并在容器启动时执行它。 以上是几种可能解决"no main manifest attribute"错误的方法。根据具体情况选择适合的方法进行尝试,以解决该问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值