maven 打包可执行jar包的坑

写作背景:首先是从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, 出错了:

这里写图片描述

可是我在myeclipse中直接运行时没错的:
这里写图片描述

查了一下发现是包没引入,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

运行后,没报错

猜你喜欢

转载自blog.csdn.net/change_on/article/details/79379400