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