maven 打包可执行jar包的坑

时间:2022-03-16 18:31:36

写作背景:首先是从20天的年假回来,新年的第一个任务是将用户行为系统自动化。需要将Java项目打包成一个可执行的jar包,让shell脚本定时执行。

我一直习惯于用maven的maven install打包,在打包之前maven clean清理。于是,myeclipse的java project右键,点击 run as,在选择maven clean,再maven install,就打包出一个可执行jar,于是兴高采烈地运行,java -cp xxx.jar com…Main, 出错了:

maven 打包可执行jar包的坑

可是我在myeclipse中直接运行时没错的:
maven 打包可执行jar包的坑

查了一下发现是包没引入,hadoop-mapreduce-client-jobclient,hadoop-mapreduce-client-common,可是,maven里面明明包含有这两个包。于是我在项目新建了一个lib文件夹,将两个jar包拷进去,加到classpath,再次运行,就没问题了,可是,碰巧这个类只需要这两个包,有的类是包含spring,依赖很多包的,导包的方式不可取。折腾了一下,终于知道,maven在打包是是不会将依赖包打包进去的,于是,我需要将依赖包打包在一个lib文件夹,用一下的maven插件:

<plugin>  
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>prepare-package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<outputDirectory>${project.build.directory}/lib</outputDirectory>
<overWriteReleases>false</overWriteReleases>
<overWriteSnapshots>false</overWriteSnapshots>
<overWriteIfNewer>true</overWriteIfNewer>
</configuration>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<mainClass>com...Main/默认主类</mainClass>
</manifest>
</archive>
</configuration>
</plugin>

接下来运行,打包出新的jar包和一个lib文件夹,于是,再次运行,还是报错。。。报找不到log4j,于是,点击project,clean一下项目,再次maven install,再次运行,还是报错,跟上面的一样。我在网上折腾了好久,终于知道,是执行jar的语句写错了,引进lib的jar包需要明确指定.将命令行改为:

java -cp .:./opt/lib/:/opt/mytest-1.0.jar com...Main

运行,可以了。然后打包到服务器,服务器只有1G内存,一运行,又出错了,这个错误很经典:

java.lang.Exception: java.lang.OutOfMemoryError: Java heap space

相必是服务器的内存不够,要指定一下,于是将命令行修改为:

java -Xmn128M -Xms512M -Xmx512M -cp .:./opt/lib/:/opt/mytest-1.0.jar com...Main

运行后,没报错