Maven的Snapshot版本与Release版本
2014-12-30 11:28
260 查看
1. Snapshot版本代表不稳定、尚处于开发中的版本
2. Release版本则代表稳定的版本
3. 什么情况下该用SNAPSHOT?
协同开发时,如果A依赖构件B,由于B会更新,B应该使用SNAPSHOT来标识自己。这种做法的必要性可以反证如下:
a.如果B不用SNAPSHOT,而是每次更新后都使用一个稳定的版本,那版本号就会升得太快,每天一升甚至每个小时一升,这就是对版本号的滥用。
b.如果B不用SNAPSHOT, 但一直使用一个单一的Release版本号,那当B更新后,A可能并不会接受到更新。因为A所使用的repository一般不会频繁更新release版本的缓存(即本地repository),所以B以不换版本号的方式更新后,A在拿B时发现本地已有这个版本,就不会去远程Repository下载最新的B
4. 不用Release版本,在所有地方都用SNAPSHOT版本行不行?
不行。正式环境中不得使用snapshot版本的库。
比如说,今天你依赖某个snapshot版本的第三方库成功构建了自己的应用,明天再构建时可能就会失败,因为今晚第三方可能已经更新了它的snapshot库。你再次构建时,Maven会去远程repository下载snapshot的最新版本,你构建时用的库就是新的jar文件了,这时正确性就很难保证了。
2. Release版本则代表稳定的版本
3. 什么情况下该用SNAPSHOT?
协同开发时,如果A依赖构件B,由于B会更新,B应该使用SNAPSHOT来标识自己。这种做法的必要性可以反证如下:
a.如果B不用SNAPSHOT,而是每次更新后都使用一个稳定的版本,那版本号就会升得太快,每天一升甚至每个小时一升,这就是对版本号的滥用。
b.如果B不用SNAPSHOT, 但一直使用一个单一的Release版本号,那当B更新后,A可能并不会接受到更新。因为A所使用的repository一般不会频繁更新release版本的缓存(即本地repository),所以B以不换版本号的方式更新后,A在拿B时发现本地已有这个版本,就不会去远程Repository下载最新的B
4. 不用Release版本,在所有地方都用SNAPSHOT版本行不行?
不行。正式环境中不得使用snapshot版本的库。
比如说,今天你依赖某个snapshot版本的第三方库成功构建了自己的应用,明天再构建时可能就会失败,因为今晚第三方可能已经更新了它的snapshot库。你再次构建时,Maven会去远程repository下载snapshot的最新版本,你构建时用的库就是新的jar文件了,这时正确性就很难保证了。
相关文章推荐
- Maven:版本管理 【SNAPSHOT】【Release】【maven-release-plugin】【nexus】
- Maven的Snapshot版本与Release版本
- Maven的Snapshot版本与Release版本
- maven 中snapshot版本和release版本的区别
- Maven的Snapshot版本与Release版本
- Maven中Snapshot版本与Release版本的区别
- 【Maven】Snapshot和Release版本的区别
- 关于maven版本管理 SNAPSHOT RELEASE(version)
- Maven的Snapshot版本与Release版本
- 【Maven】Snapshot和Release版本的区别
- maven的snapshot和release版本的区别
- maven的snapshot版本与release版本
- (转) maven snapshot和release版本的区别
- 理解Maven中的SNAPSHOT版本和正式版本
- Maven两个snapshot版本项目依赖,无法deploy
- 如何发布maven的SNAPSHOT版本
- 版本号轨范,镜像版本SNAPSHOT,LATEST 和 RELEASE 版本
- Maven实践:版本管理 SNAPSHOT
- maven快照与发布,RELEASE与SNAPSHOT
- Maven使用nexus配置,SNAPSHOT版本介绍及发布jar到nexus