在使用maven过程中,我们在开发阶段经常性的会有很多公共库处于不稳定状态,随时需要修改并发布,可能一天就要发布一次,遇到bug时,甚至一天要发布N次。我们知道,maven的依赖管理是基于版本管理的,对于发布状态的artifact,如果版本号相同,即使我们内部的镜像服务器上的组件比本地新,maven也不会主动下载的。如果我们在开发阶段都是基于正式发布版本来做依赖管理,那么遇到这个问题,就需要升级组件的版本号,可这样就明显不符合要求和实际情况了。但是,如果是基于快照版本,那么问题就自热而然的解决了,而maven已经为我们准备好了这一切。
maven中的仓库分为两种,snapshot快照仓库和release发布仓库。snapshot快照仓库用于保存开发过程中的不稳定版本,release正式仓库则是用来保存稳定的发行版本。定义一个组件/模块为快照版本,只需要在pom文件中在该模块的版本号后加上-SNAPSHOT即可(注意这里必须是大写),如下:
<groupId>cc.mzone</groupId><artifactId>m1</artifactId><version>0.1-SNAPSHOT</version><packaging>jar</packaging>
maven2会根据模块的版本号(pom文件中的version)中是否带有-SNAPSHOT来判断是快照版本还是正式版本。如果是快照版本,那么在mvn deploy时会自动发布到快照版本库中,而使用快照版本的模块,在不更改版本号的情况下,直接编译打包时,maven会自动从镜像服务器上下载最新的快照版本。如果是正式发布版本,那么在mvn deploy时会自动发布到正式版本库中,而使用正式版本的模块,在不更改版本号的情况下,编译打包时如果本地已经存在该版本的模块则不会主动去镜像服务器上下载。
所以,我们在开发阶段,可以将公用库的版本设置为快照版本,而被依赖组件则引用快照版本进行开发,在公用库的快照版本更新后,我们也不需要修改pom文件提示版本号来下载新的版本,直接mvn执行相关编译、打包命令即可重新下载最新的快照库了,从而也方便了我们进行开发。
来源:http://www.mzone.cc/article/277.html
分享到:
相关推荐
在软件开发过程中,尤其是...综上所述,Maven的快照版本和发布版本提供了灵活的版本管理策略,帮助多团队协作开发更有效地同步和集成代码。在实际应用中,需要权衡其优点和潜在风险,合理使用快照版本以优化开发流程。
使用这些服务时,你可以根据项目的具体需求来筛选版本,例如选择稳定版(如release)而非快照版(如snapshot)。同时,确保你引入的依赖与你的项目兼容,避免版本冲突。 在获取到确切的Maven坐标后,你需要将其添加...
* releases:内部的模块中release模块的发布仓库 * snapshots:发布内部的SNAPSHOT模块的仓库 * 3rd party:第三方依赖的仓库,这个数据通常是由内部人员自行下载之后发布上去 * proxy:类型的仓库,从远程中央...
`maven-release-plugin`插件通过一系列命令实现了自动化的版本发布和代码分支管理。以下是几个关键命令及其功能: - **release:prepare**: 准备发布版本。此命令将快照版本号更新为发布版本号,并基于修改后的POM...
- **Release与Snapshots区分**:清晰地区分发布版构件和服务快照版构件。 - **路由**:根据特定请求提供特定仓库,提高响应速度。 - **上传构件**:可通过Web界面上传特殊构件到仓库。 - **高用户体验UI**:使用...
- Snapshot仓库:用于存放开发中的快照版本,每个版本都有时间戳标识。 - Public仓库:包含公开可用的组件,如Maven中央仓库的镜像。 - Third-party仓库:存放非Maven中心仓库的第三方组件。 5. **使用Sonatype-...
在团队开发中,Maven 提供了 RELEASE 和 SNAPSHOT 两种版本类型,以适应不同阶段的需求。 - **RELEASE 版本**:代表稳定的、已发布版本。当项目达到一定成熟度并经过测试后,可以将版本号标记为RELEASE,这表明这个...
然后,在每个Maven项目中,你需要在`pom.xml`文件中定义发布工厂(release repository)和快照工厂(snapshot repository)。这将决定项目构建时部署到哪个仓库: ```xml <id>deployment-repo <url>...
- **版本控制**: 版本号 `0.0.1-SNAPSHOT` 表示这是一个快照版本。`SNAPSHOT` 代表不稳定版本,通常用于开发中的模块。 - **SNAPSHOT**: 开发中的版本。 - **Alpha**: 内部测试版,可能存在较多 bug。 - **Beta*...
LATEST 和 RELEASE 版本 9.3.2. 属性引用 9.4. 项目依赖 9.4.1. 依赖范围 9.4.2. 可选依赖 9.4.3. 依赖版本界限 9.4.4. 传递性依赖 9.4.4.1. 传递性依赖和范围 9.4.5. 冲突解决 9.4.6. 依赖管理 ...
9. **环境打包**:对于不同环境的打包,可以通过传递参数实现,例如修改版本号、区分发布版本和快照版本。 10. **避免下载依赖**:如果本地仓库已经存在某个依赖,Maven不会再下载。 11. **依赖版本指定**:每个...
SNAPSHOT是快照的意思,项目到一个阶段后,就需要发布一个正式的版本(release版本)。一次正式的发布需要这样一些工作: 在trunk中,更新pom版本从1.0-SNAPSHOT到1.0 对1.0打一个svn tag 针对tag进行mvn deploy,...
SNAPSHOT是快照的意思,项目到一个阶段后,就需要发布一个正式的版本(release版本)。一次正式的发布需要这样一些工作: 在trunk中,更新pom版本从1.0-SNAPSHOT到1.0 对1.0打一个svn tag 针对tag进行mvn deploy,...
- **RELEASE:** 发布版本,通常在发布后不会变动。 **4.5 灵活构建** - **多模块项目:** 支持复杂项目结构,便于管理和维护。 - **条件构建:** 根据不同的构建环境调整构建行为。 **4.6 生成项目站点** - **...
`SNAPSHOT` 表示快照版本,即开发中的版本;`RELEASE` 表示发布版本。 - `<packaging>` - 定义打包方式,如 `jar`、`war` 或 `pom`。 #### 四、添加依赖 在 `pom.xml` 文件中,可以通过 `<dependencies>` 标签来...
5. **版本管理**:Maven遵循严格的版本管理规则,如`SNAPSHOT`表示快照版本,每次构建可能会有所不同;`RELEASE`则表示稳定的发布版本。 6. **多模块项目**:对于大型项目,可以使用Maven的聚合功能管理多个子项目...
本文将深入探讨`repositories.xml`文件的结构、作用以及在Maven中的重要性。 `repositories.xml`是Maven的一个非常关键的配置文件,它定义了Maven从哪里获取依赖和发布工件。在默认情况下,Maven使用中央仓库...