目录
1 使用 maven-shade-plugin
2 推荐: 使用 maven-assembly-plugin
3 扩展: Maven 安装本地 jar 包到本地仓库
4 扩展: 手动生成 jar 包
5 扩展: Linux 下运行 jar 包的几种方式
5.1 阻塞式方式
5.2 后台运行方式
5.3 后台持续运行方式
5.4 其他命令扩展
1 使用 maven-shade-plugin
(1) 在项目的 pom.xml 文件中加入如下插件:
- <build>
- <plugins>
- <!-- Maven Shade Plugin -->
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-shade-plugin</artifactId>
- <version>3.2.0</version>
- <configuration>
- <createDependencyReducedPom>true</createDependencyReducedPom>
- </configuration>
- <executions>
- <execution>
- <phase>package</phase>
- <goals>
- <goal>shade</goal>
- </goals>
- <configuration>
- <transformers>
- <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
- <!-- 主类的全限定名 -->
- <mainClass>com.healchow.consumer.Main</mainClass>
- </transformer>
- </transformers>
- </configuration>
- </execution>
- </executions>
- </plugin>
- </plugins>
- </build>
(2) 然后使用 Maven 的 package 命令打包项目;
(3) 打包完成后, 即可在项目的 target 目录下看到生成的 jar 包;
(4) 不出差错的话, 使用 java -jar xxxx.jar 命令即可运行此 jar 包.
说明: 此方法在 Mac OS 系统下的 IDEA 中实施, 在 jar/META-INF / 目录下有时会出现:
ECLIPSEF.SF ECLIPSE.RSA 等文件, 并在运行 java -jar xxx.jar 时, 会抛出如下错误:
- Error: A JNI error has occurred, please check your installation and try again
- Exception in thread "main" java.lang.SecurityException: Invalid signature file digest for Manifest main attributes
- at sun.security.util.SignatureFileVerifier.processImpl(SignatureFileVerifier.java:330)
- at sun.security.util.SignatureFileVerifier.process(SignatureFileVerifier.java:263)
- at java.util.jar.JarVerifier.processEntry(JarVerifier.java:318)
- at java.util.jar.JarVerifier.update(JarVerifier.java:230)
- at java.util.jar.JarFile.initializeVerifier(JarFile.java:383)
- at java.util.jar.JarFile.getInputStream(JarFile.java:450)
- at sun.misc.URLClassPath$JarLoader$2.getInputStream(URLClassPath.java:977)
- at sun.misc.Resource.cachedInputStream(Resource.java:77)
- at sun.misc.Resource.getByteBuffer(Resource.java:160)
- at java.NET.URLClassLoader.defineClass(URLClassLoader.java:454)
- at java.NET.URLClassLoader.access$100(URLClassLoader.java:73)
- at java.NET.URLClassLoader$1.run(URLClassLoader.java:368)
- at java.NET.URLClassLoader$1.run(URLClassLoader.java:362)
- at java.security.AccessController.doPrivileged(Native Method)
- at java.NET.URLClassLoader.findClass(URLClassLoader.java:361)
- at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
- at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
- at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
- at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:495)
解决办法是: 手动删除 jar 包中 META-INF/*.RSA META-INF/*.DSA META-INF/*.SF 这些文件, 然后就可行了.
2 推荐: 使用 maven-assembly-plugin
(1) 在项目的 pom.xml 文件中加入如下插件:
- <build>
- <plugins>
- <!-- Maven Assembly Plugin -->
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-assembly-plugin</artifactId>
- <version>2.4.1</version>
- <configuration>
- <!-- get all project dependencies -->
- <descriptorRefs>
- <descriptorRef>jar-with-dependencies</descriptorRef>
- </descriptorRefs>
- <!-- MainClass in mainfest make a executable jar -->
- <archive>
- <manifest>
- <mainClass>com.healchow.consumer.Main</mainClass>
- </manifest>
- </archive>
- </configuration>
- <executions>
- <!-- 配置执行器 -->
- <execution>
- <id>make-assembly</id>
- <!-- 绑定到 package 命令的生命周期上 -->
- <phase>package</phase>
- <goals>
- <!-- 只运行一次 -->
- <goal>single</goal>
- </goals>
- </execution>
- </executions>
- </plugin>
- </plugins>
- </build>
(2) 然后使用 Maven 的 package 命令打包项目;
(3) 打包完成后, 即可在项目的 target 目录下看到生成的 jar 包, 其中 xxx-jar-with-dependencies.jar 是包含依赖 jar 包的 jar 文件, 另一个不包含依赖 jar 包;
(4) 使用 java -jar xxxx.jar 命令即可运行此 jar 包.
3 扩展: Maven 安装本地 jar 包到本地仓库
命令如下:
mvn install:install-file -Dfile=base-util-1.0.RELEASE.jar -DgroupId=com.healchow -DartifactId=base-util -Dversion=1.0.RELEASE -Dpackaging=jar
其他命令, 参考这篇博客: Maven 常用命令.
4 扩展: 手动生成 jar 包
创建可执行 jar 包的关键在于: 让 java -jar 命令知道 jar 包中的主方法属于哪个类 -- 要配置主类的全限定名.
步骤如下:
(1) 打包指定的项目:
进入项目所在的根目录, 以 Linux 系统为例:
项目名是 java-test, 其所在的目录是 / data/project/java-test;
main 方法所属的类的全限定名是 com.healchow.test.Main:
- # 进入项目所在的根目录:
- cd /data/project
- # 运行打包命令:
- jar cvfe test.jar java-test.com.healchow.test.Main java-test
上述命令说明: 将 java-test 目录下的所有文件打包到 test.jar 中, 并指定主类的全限定名称, 这里要指明主类所在的文件夹.
关于 jar 命令的其他用法, 参考如下:
- # 用法: jar {
- ctxui
- }[vfmn0PMe] [jar-file] [manifest-file] [entry-point] [-C dir] files ...
- # 选项:
-c 创建新档案
-t 列出档案目录
-x 从档案中提取指定的 (或所有) 文件
-u 更新现有档案
-v 在标准输出中生成详细输出
-f 指定档案文件名
-m 包含指定清单文件中的清单信息
-n 创建新档案后执行 Pack200 规范化
-e 为捆绑到可执行 jar 文件的独立应用程序指定应用程序入口点
-0 仅存储; 不使用任何 ZIP 压缩
-P 保留文件名中的前导 '/' (绝对路径) 和 ".." (父目录) 组件
-M 不创建条目的清单文件
-i 为指定的 jar 文件生成索引信息
-C 更改为指定的目录并包含以下文件
- # 如果任何文件为目录, 则对其进行递归处理.
- # 清单文件名, 档案文件名和入口点名称的指定顺序 与'm', 'f' 和'e' 标记的指定顺序相同.
示例 1: 将两个类文件归档到一个名为 classes.jar 的档案中:
jar cvf classes.jar Foo.class Bar.class
示例 2: 使用现有的清单文件'mymanifest' 并将 foo/ 目录中的所有文件归档到'classes.jar' 中:
jar cvfm classes.jar mymanifest -C foo/ .
(2) 运行 jar 包:
用解压软件打开上一步生成的 jar 包, 查看 META-INF/MANIFEST.MF 文件, 里面如果有 Main-Class: com.healchow.test.Main, 说明打包成功.
- # 在当前目录下, 运行 jar 包:
- java -jar test.jar
5 扩展: Linux 下运行 jar 包的几种方式
5.1 阻塞式方式
java -jar xxx.jar
特点: 当前终端的会话窗口被阻塞, 可按 CTRL + C 中断程序的运行, 或者直接关闭会话窗口 -- 此时 jar 程序将终止.
5.2 后台运行方式
- # 通过 "&" 符号实现后台运行:
- java -jar xxx.jar &
特点: 当前终端的会话窗口不会被阻塞, 但是如果关闭当前窗口, 程序将终止运行.
5.3 后台持续运行方式
- # 通过 "nohup" 命令实现后台运行:
- nohup java -jar xxx.jar &
nohup 命令是不挂断运行命令的意思.
特点: 当用户退出或终端关闭时, 程序的运行不受影响.
说明: 用 nohup 命令运行任务时, 默认情况下这个任务的所有输出都将被重定向到 nohup.out 文件中, 除非另外指定输出文件. 指定输出文件方式为:
- # 将输出重定向到 xxx.log 文件中:
- nohup java -jar xxx.jar> xxx.log &
> 符号是重定向符, 实现: 把它之前命令的所有输出信息重定向到后面的文件中, 而不是显示到屏幕上.
5.4 其他命令扩展
1 通过 jobs 命令可以查看后台运行任务, 会给每个任务指定一个编号.
2 通过 fg 命令可以把指定编号的后台任务调回到前台控制, 如: fg 10 -- 把 10 号任务调回前台.
3 查看占用某个端口的进程:
- netstat -nlp | grep 2181
- # 下述结果说明进程号 pid=18434 的 java 进程占用了 2181 端口
- tcp 0 0 :::2181 :::* LISTEN 18434/java
参考资料
使用 Maven 的 assembly 插件实现自定义打包
Maven 构建可执行的 jar 包 (包含依赖 jar 包)
Linux 下利用 nohup 后台运行 jar 文件包程序
来源: https://www.cnblogs.com/shoufeng/p/10624968.html