标签:
在项目中应用snapshot和release库,应用snapshot和release库达到不同环境下发布不同的版本的目的,首先看一个pom文件的定义:
<project> <modelVersion>4.0.0</modelVersion> <groupId>cc.mzone</groupId> <artifactId>myjar</artifactId> <version>${project.release.version}</version> <packaging>jar</packaging> <distributionManagement> <repository> <id>mzone-release</id> <url>http://192.168.1.88/nexus/content/repositories/mzone-release</url> </repository> <snapshotRepository> <id>mzone-snapshot</id> <url>http://192.168.1.88/nexus/content/repositories/mzone-snapshot</url> </snapshotRepository> </distributionManagement> <properties> <project.release.version>0.1-SNAPSHOT</project.release.version> </properties> <profiles> <profile> <id>product</id> <properties> <project.release.version>0.1</project.release.version> </properties> </profile> </profiles> </project>
首先我们看到pom文件中version的定义是采用占位符的形式,这样的好处是可以根据不同的profile来替换版本信息,比如maven默认是使用0.1-SNAPSHOT作为该模块的版本。
1、如果在发布时使用mvn deploy -P product的命令,那么会自动使用0.1作为发布版本,那么根据maven处理snapshot和release的规则,由于版本号后不带-SNAPSHOT故当成是正式发布版本,会被发布到release仓库;
2、如果发布时使用mvn deploy命令,那么就会使用默认的版本号0.1-SNAPSHOT,此时maven会认为是快照版本,会自动发布到快照版本库。
在distributionManagement段中配置的是snapshot快照库和release发布库的地址,我这里是采用nexus作为镜像服务器。对于版本库主要是id和url的配置,配置完成后就可以通过mvn deploy进行发布了,当然了,如果你的镜像服务器需要用户名和密码,那么还需要在maven的settings.xml文件中做如下配置:
<servers> <server> <id>mzone-release</id> <username>deployment</username> <password>deployment</password> </server> <server> <id>mzone-snapshot</id> <username>deployment</username> <password>deployment</password> </server> </servers>
注意这里配置的server的id必须和pom文件中的distributionManagement对应仓库的id保持一致,maven在处理发布时会根据id查找用户名称和密码进行登录和文件的上传发布。
我们这里通过profile的定义就可以在发布灵活切换snapshot快照版本和release正式版本了,在被依赖的组件中也可以使用profile来定义在开发阶段使用快照库,在发布阶段使用正式库的功能,只需要在不同的profile中覆盖默认的properties属性值即可。
maven2-snapshot快照库和release发布库的应用
标签:
原文地址:http://www.cnblogs.com/hwaggLee/p/4579464.html