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, 出错了:

maven 打包可执行jar包的坑_第1张图片

可是我在myeclipse中直接运行时没错的:
maven 打包可执行jar包的坑_第2张图片

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

<plugin>  
                  <groupId>org.apache.maven.pluginsgroupId>  
                  <artifactId>maven-dependency-pluginartifactId>  
                  <executions>  
                        <execution>  
                              <id>copy-dependenciesid>  
                              <phase>prepare-packagephase>  
                              <goals>  
                                    <goal>copy-dependenciesgoal>  
                              goals>  
                              <configuration>  
                                    <outputDirectory>${project.build.directory}/liboutputDirectory>  
                                    <overWriteReleases>falseoverWriteReleases>  
                                    <overWriteSnapshots>falseoverWriteSnapshots>  
                                    <overWriteIfNewer>trueoverWriteIfNewer>  
                              configuration>  
                        execution>  
                  executions>  
            plugin>  
            <plugin>  
                  <groupId>org.apache.maven.pluginsgroupId>  
                  <artifactId>maven-jar-pluginartifactId>  
                  <configuration>  
                        <archive>  
                              <manifest>  
                                    <addClasspath>trueaddClasspath>  
                                    <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

运行后,没报错

你可能感兴趣的:(java)