当前位置:   article > 正文

(转)Maven把项目依赖的所有jar包都打到同一个jar中_maven 多个jar 包打成一个包

maven 多个jar 包打成一个包

【转载原因:使用文章方法:“推荐:maven-assembly-plugin"方法打包,把所有依赖都打入jar包。并且可以运行,瘦风大神写得非常详细!】

【原文地址:https://www.cnblogs.com/shoufeng/p/10624968.html#%E6%8E%A8%E8%8D%90-%E4%BD%BF%E7%94%A8maven-assembly-plugin

目录

目录

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文件中加入如下插件:

  1. <build>
  2. <plugins>
  3. <!-- Maven Shade Plugin -->
  4. <plugin>
  5. <groupId>org.apache.maven.plugins</groupId>
  6. <artifactId>maven-shade-plugin</artifactId>
  7. <version>3.2.0</version>
  8. <configuration>
  9. <createDependencyReducedPom>true</createDependencyReducedPom>
  10. </configuration>
  11. <executions>
  12. <execution>
  13. <phase>package</phase>
  14. <goals>
  15. <goal>shade</goal>
  16. </goals>
  17. <configuration>
  18. <transformers>
  19. <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
  20. <!-- 主类的全限定名 -->
  21. <mainClass>com.healchow.consumer.Main</mainClass>
  22. </transformer>
  23. </transformers>
  24. </configuration>
  25. </execution>
  26. </executions>
  27. </plugin>
  28. </plugins>
  29. </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时, 会抛出如下错误:

  1. Error: A JNI error has occurred, please check your installation and try again
  2. Exception in thread "main" java.lang.SecurityException: Invalid signature file digest for Manifest main attributes
  3. at sun.security.util.SignatureFileVerifier.processImpl(SignatureFileVerifier.java:330)
  4. at sun.security.util.SignatureFileVerifier.process(SignatureFileVerifier.java:263)
  5. at java.util.jar.JarVerifier.processEntry(JarVerifier.java:318)
  6. at java.util.jar.JarVerifier.update(JarVerifier.java:230)
  7. at java.util.jar.JarFile.initializeVerifier(JarFile.java:383)
  8. at java.util.jar.JarFile.getInputStream(JarFile.java:450)
  9. at sun.misc.URLClassPath$JarLoader$2.getInputStream(URLClassPath.java:977)
  10. at sun.misc.Resource.cachedInputStream(Resource.java:77)
  11. at sun.misc.Resource.getByteBuffer(Resource.java:160)
  12. at java.net.URLClassLoader.defineClass(URLClassLoader.java:454)
  13. at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
  14. at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
  15. at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
  16. at java.security.AccessController.doPrivileged(Native Method)
  17. at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
  18. at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
  19. at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
  20. at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
  21. 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文件中加入如下插件:

  1. <build>
  2. <plugins>
  3. <!-- Maven Assembly Plugin -->
  4. <plugin>
  5. <groupId>org.apache.maven.plugins</groupId>
  6. <artifactId>maven-assembly-plugin</artifactId>
  7. <version>2.4.1</version>
  8. <configuration>
  9. <!-- get all project dependencies -->
  10. <descriptorRefs>
  11. <descriptorRef>jar-with-dependencies</descriptorRef>
  12. </descriptorRefs>
  13. <!-- MainClass in mainfest make a executable jar -->
  14. <archive>
  15. <manifest>
  16. <mainClass>com.healchow.consumer.Main</mainClass>
  17. </manifest>
  18. </archive>
  19. </configuration>
  20. <executions>
  21. <!-- 配置执行器 -->
  22. <execution>
  23. <id>make-assembly</id>
  24. <!-- 绑定到package命令的生命周期上 -->
  25. <phase>package</phase>
  26. <goals>
  27. <!-- 只运行一次 -->
  28. <goal>single</goal>
  29. </goals>
  30. </execution>
  31. </executions>
  32. </plugin>
  33. </plugins>
  34. </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:

  1. # 进入项目所在的根目录:
  2. cd /data/project
  3. # 运行打包命令:
  4. jar cvfe test.jar java-test.com.healchow.test.Main java-test

上述命令说明: 将java-test目录下的所有文件打包到test.jar中, 并指定主类的全限定名称, 这里要指明主类所在的文件夹.

关于jar命令的其他用法, 参考如下:

  1. # 用法: jar {ctxui}[vfmn0PMe] [jar-file] [manifest-file] [entry-point] [-C dir] files ...
  2. # 选项:
  3. -c 创建新档案
  4. -t 列出档案目录
  5. -x 从档案中提取指定的 (或所有) 文件
  6. -u 更新现有档案
  7. -v 在标准输出中生成详细输出
  8. -f 指定档案文件名
  9. -m 包含指定清单文件中的清单信息
  10. -n 创建新档案后执行 Pack200 规范化
  11. -e 为捆绑到可执行 jar 文件的独立应用程序指定应用程序入口点
  12. -0 仅存储; 不使用任何 ZIP 压缩
  13. -P 保留文件名中的前导 '/' (绝对路径) 和 ".." (父目录) 组件
  14. -M 不创建条目的清单文件
  15. -i 为指定的 jar 文件生成索引信息
  16. -C 更改为指定的目录并包含以下文件
  17. # 如果任何文件为目录, 则对其进行递归处理。
  18. # 清单文件名, 档案文件名和入口点名称的指定顺序 与 'm', 'f''e' 标记的指定顺序相同。
  19. 示例 1: 将两个类文件归档到一个名为 classes.jar 的档案中:
  20. jar cvf classes.jar Foo.class Bar.class
  21. 示例 2: 使用现有的清单文件 'mymanifest' 并将 foo/ 目录中的所有文件归档到 'classes.jar' 中:
  22. jar cvfm classes.jar mymanifest -C foo/ .

(2) 运行jar包:

用解压软件打开上一步生成的jar包, 查看META-INF/MANIFEST.MF文件, 里面如果有Main-Class: com.healchow.test.Main, 说明打包成功.

  1. # 在当前目录下, 运行jar包:
  2. java -jar test.jar

5 扩展: Linux下运行jar包的几种方式

5.1 阻塞式方式

java -jar xxx.jar

特点: 当前终端的会话窗口被阻塞, 可按CTRL + C中断程序的运行, 或者直接关闭会话窗口 —— 此时jar程序将终止.

5.2 后台运行方式

  1. # 通过"&"符号实现后台运行:
  2. java -jar xxx.jar &

特点: 当前终端的会话窗口不会被阻塞, 但是如果关闭当前窗口, 程序将终止运行.

5.3 后台持续运行方式

  1. # 通过"nohup"命令实现后台运行:
  2. nohup java -jar xxx.jar &

nohup命令是不挂断运行命令的意思.

特点: 当用户退出或终端关闭时, 程序的运行不受影响.

说明: 用nohup命令运行任务时, 默认情况下这个任务的所有输出都将被重定向到nohup.out文件中, 除非另外指定输出文件. 指定输出文件方式为:

  1. # 将输出重定向到xxx.log文件中:
  2. nohup java -jar xxx.jar > xxx.log &

> 符号是重定向符, 实现: 把它之前命令的所有输出信息重定向到后面的文件中, 而不是显示到屏幕上.

5.4 其他命令扩展

① 通过jobs命令可以查看后台运行任务, 会给每个任务指定一个编号.
② 通过fg命令可以把指定编号的后台任务调回到前台控制, 如: fg 10 —— 把10号任务调回前台.
③ 查看占用某个端口的进程:

  1. netstat -nlp | grep 2181
  2. # 下述结果说明进程号pid=18434的java进程占用了2181端口
  3. tcp 0 0 :::2181 :::* LISTEN 18434/java

 

参考资料

使用Maven的assembly插件实现自定义打包

Maven构建可执行的jar包(包含依赖jar包)

linux下利用nohup后台运行jar文件包程序

版权声明

作者: 马瘦风(https://healchow.com)

出处: 博客园 马瘦风的博客(https://www.cnblogs.com/shoufeng)

感谢阅读, 如果文章有帮助或启发到你, 点个[好文要顶?] 或 [推荐?] 吧?

本文版权归博主所有, 欢迎转载, 但 [必须在文章页面明显位置标明原文链接], 否则博主保留追究相关人员法律责任的权利.

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/308137
推荐阅读
相关标签
  

闽ICP备14008679号