一、maven clean 是清除target目录下的以前打好的jar包或者是war包;java
二、maven build是从新对该maven项目进行打包,这里须要手动的输入打包的命令 -X packageapache
上面的两部命令合在一块儿 maven install是对上面两个命令的集合,既是经过maven自带的原生命令,同时执行了clean 和build,比较节省时间;eclipse
那么问题就来了当时为何我单独执行会出错呢,这就能够说明 maven 对eclipse外带的插件执行命不友好;maven
下面是一个大神的另外一个问题的总结;ui
以前写代码的过程当中曾经遇到过问题,用mvn install后,新改的内容不生效,必定要后来使用mvn clean install 才生效,因而想看看clean和不clean的区别。.net
就如你们知道的,maven在执行一个生命周期的命令的是时候将会执行以前的全部生命周期操做,好比执行mvn install,会执行前面一系列的动做包括 compile , package , test 等,具体请查看maven的官方文档。这个特性使maven的命令更加简洁易用。插件
再来分析原来的问题,为何修改的内容不生效,确定是最终打出来的war包中的内容没有更新,而war包中会依赖其余子工程的jar包,若是jar 包没有更新过,那war包调用老的jar包也会致使新内容不生效。定位到问题的缘由应该是jar包没有用最新的资源(java或者配置文件),那jar包 又是何时,谁去打的呢。xml
上面咱们提到咱们执行mvn install的时候会先执行mvn package,maven就是经过这个生命周期来根据用户配置,进行打包(war、jar或者其余),这会在每一个工程 pom.xml 文件中设置,相似以下:blog
<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">
...
<packaging>war</packaging>
...
</project>
这里指定package的时候打成一个war包,改为jar,就会被打成jar包。
咱们看jar形式的状况,mvn package 会调用 maven-jar-plugin 这个插件进行打包。
下面咱们作一些实验来看这个插件打包的时候的状况
1. 修改target目录下打好的jar包中class以及配置文件的内容,在运行命令mvn package,结果target包中的内容没有被覆盖。
2. 修改源代码中的内容,再运行命令mvn package,结果target包中的内容被覆盖了,产生了新的包。
3. 修改target目录下打好的jar包中的内容,运行命令mvn package -Djar.forceCreation,这个参数应该是强制建立jar包,因此结果target中的jar包内容被覆盖了,产生了新的jar包。
根据上面的实验好像仍是不能解释何时应该用clean将target下面的内容删除从新生成,jar包,不过至少是明白了一些规则。
总结1. 理论上来说不作mvn clean 获得的jar包应该是最新的,除非其余方式修改jar包中的内容而不修改源代码。2. 平时能够用mvn install,而不进行chean节省时间(若是你以为节省时间多的话),但最保险仍是用 mvn clean install 生成最新的jar包或其余包3. 不想用mvn clean又想保证jar包最新,建议添加 -Djar.forceCreation 参数--------------------- 做者:liangwanmian 来源:CSDN 原文:https://blog.csdn.net/liangwanmian/article/details/78458159 版权声明:本文为博主原创文章,转载请附上博文连接!