背 景
将自己的Java代码或者Scala代码打成Jar包部署是最常用的操作之一了,这里介绍两种,利用Maven插件打包
和IDEA自带的图形界面操作打包
;
利用Maven插件打包
:
优点:方便,打包基本不会出现异常,稳定;
缺点:非要说的话就是需要配置Maven,对Maven不熟悉的小白来说有点拦路虎;
IDEA自带的图形界面操作打包
:
优点:IDEA自带,不需要安装任何插件,图形界面点点点就行,操作简单;
缺点:有时打出来的包运行的时候会有莫名的异常,个人不是很了解其内部打包的原理,解读不深,同时用的也少,只会用一些简单小项目的临时打包;
不多BB,进入实战教学;
利用Maven插件打包
首先,写好一段代码,就最简单的Java Hello World吧,包名和代码如图1所示;
然后配置好maven环境的pom.xml
文件,利用插件maven-assembly-plugin(这类的插件很多,感兴趣的可以网上搜索下,这个就以这个为例子,比较常用)
,具体内容如下,你只要添加<build>……</build>
这个标签内的内容;
<?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>org.example</groupId>
<artifactId>maven_package</artifactId>
<version>1.0-SNAPSHOT</version>
<build>
<plugins>
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
<archive>
<manifest>
<mainClass></mainClass>
</manifest>
</archive>
</configuration>
<executions>
<execution>
<id>make-assembly</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
Maven检测到配置文件的内容发生了更改就会弹出图2的1出的提示,这个时候你只要Import Changes
即可,来下载刚刚我们配置的插件,插件安装好以后好了以后我们打开图2的2处内容,一般打包先要点一下clear
操作,做一下容错处理,不然有可能报错说目标Jar包已存在;然后再点击package
进行打包,一顿操作打印日志后,就能看到图2的3处的taeget文件夹下多了两个Jar包
maven_package-1.0-SNAPSHOT.jar
:只将自己写的该部分代码打成Jar包
maven_package-1.0-SNAPSHOT-jar-with-dependencies
:会把自己写的这段代码的依赖也打入Jar包;
最终项目发布哪个Jar包,要根据你生产环境是否有这些依赖来决定,一般要是偷懒检查又要保证Jar包能正常使用,会推荐发布maven_package-1.0-SNAPSHOT-jar-with-dependencies
的Jar包;
IDEA自带的图形界面操作打包
1)将程序打成Jar包,如图3,点击菜单栏File,选择Project Structure…,跳转图4,然后选择Artifact,然后中间栏的“+”号,然后选择Jar,选择From modules with dependence,然后调转界图5,图5重点说一下:
- 第一点:JAR files from libraries,如果选择了“extract to the target JAR”则只会打包自己的程序,如果勾选了“copy to the out directory and link via manifest”则会吧Maven依赖的所有Jar包都打包出来,比如那一些了的hadoop Jar包,这里我们显然不需要这一些列Jar,因为集群里面都有,所以勾选“extract to the target JAR”;
- 第二点:选择打包的路劲,最好保留到…/src/即可,如“D:\workspace\hadoop_mapreduce\src\”,后面的就不要带出来,因为如果你文件排版不规范的话,打包太细,会遗漏文件,坑的自己吐血的那种;
- 第三点:如果反复打包,会报错图6,找到该报错所说的文件,删除即可。
2)以上一切就绪后,点击确定跳转图7,注意下标红部分,Name看不顺眼可以改,一切好了后,点击Apply 和Ok后会回到主界面;
3)然后如图8,点击菜单栏的Build,选择Build Artifact,跳转图9,选择Build,即可大功告成;
4)在该项目下,如图10,多了个out folder,里面的jar包就是你想要的(图10 我测试了很多功能,打包了多次,实际上只会有一个jar包和folder);
5)将最终的Jar上传到集群即可完成 部署。