http://www.mzone.cc/article/279.html

转载声明] 转载时必须标注:本文来源于铁木箱子的博客http://www.mzone.cc
[本文地址] 本文永久地址是:http://www.mzone.cc/article/279.html

在之前的文章中介绍了maven2中snapshot快照库和release发布库的区别和作用,请参看http://www.mzone.cc/article/277.html这篇文章。我今天这里要介绍的是如何在项目中应用snapshot和release库,应用snapshot和release库达到不同环境下发布不同的版本的目的,首先看一个pom文件的定义:

  1. <project>
  2. <modelVersion>4.0.0</modelVersion>
  3. <groupId>cc.mzone</groupId>
  4. <artifactId>myjar</artifactId>
  5. <version>${project.release.version}</version>
  6. <packaging>jar</packaging>
  7. <distributionManagement>
  8. <repository>
  9. <id>mzone-release</id>
  10. <url>http://192.168.1.88/nexus/content/repositories/mzone-release</url>
  11. </repository>
  12. <snapshotRepository>
  13. <id>mzone-snapshot</id>
  14. <url>http://192.168.1.88/nexus/content/repositories/mzone-snapshot</url>
  15. </snapshotRepository>
  16. </distributionManagement>
  17. <properties>
  18. <project.release.version>0.1-SNAPSHOT</project.release.version>
  19. </properties>
  20. <profiles>
  21. <profile>
  22. <id>product</id>
  23. <properties>
  24. <project.release.version>0.1</project.release.version>
  25. </properties>
  26. </profile>
  27. </profiles>
  28. </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文件中做如下配置:

  1. <servers>
  2. <server>
  3. <id>mzone-release</id>
  4. <username>deployment</username>
  5. <password>deployment</password>
  6. </server>
  7. <server>
  8. <id>mzone-snapshot</id>
  9. <username>deployment</username>
  10. <password>deployment</password>
  11. </server>
  12. </servers>

注意这里配置的server的id必须和pom文件中的distributionManagement对应仓库的id保持一致,maven在处理发布时会根据id查找用户名称和密码进行登录和文件的上传发布。

我们这里通过profile的定义就可以在发布灵活切换snapshot快照版本和release正式版本了,在被依赖的组件中也可以使用profile来定义在开发阶段使用快照库,在发布阶段使用正式库的功能,只需要在不同的profile中覆盖默认的properties属性值即可。

==============http://www.mzone.cc/article/277.html

http://www.mzone.cc/article/277.html

在使用maven过程中,我们在开发阶段经常性的会有很多公共库处于不稳定状态,随时需要修改并发布,可能一天就要发布一次,遇到bug时,甚至一天要发布N次。我们知道,maven的依赖管理是基于版本管理的,对于发布状态的artifact,如果版本号相同,即使我们内部的镜像服务器上的组件比本地新,maven也不会主动下载的。如果我们在开发阶段都是基于正式发布版本来做依赖管理,那么遇到这个问题,就需要升级组件的版本号,可这样就明显不符合要求和实际情况了。但是,如果是基于快照版本,那么问题就自热而然的解决了,而maven已经为我们准备好了这一切。

maven中的仓库分为两种,snapshot快照仓库和release发布仓库。snapshot快照仓库用于保存开发过程中的不稳定版本,release正式仓库则是用来保存稳定的发行版本。定义一个组件/模块为快照版本,只需要在pom文件中在该模块的版本号后加上-SNAPSHOT即可(注意这里必须是大写),如下:

  1. <groupId>cc.mzone</groupId>
  2. <artifactId>m1</artifactId>
  3. <version>0.1-SNAPSHOT</version>
  4. <packaging>jar</packaging>

maven2会根据模块的版本号(pom文件中的version)中是否带有-SNAPSHOT来判断是快照版本还是正式版本。如果是快照版本,那么在mvn deploy时会自动发布到快照版本库中,而使用快照版本的模块,在不更改版本号的情况下,直接编译打包时,maven会自动从镜像服务器上下载最新的快照版本。如果是正式发布版本,那么在mvn deploy时会自动发布到正式版本库中,而使用正式版本的模块,在不更改版本号的情况下,编译打包时如果本地已经存在该版本的模块则不会主动去镜像服务器上下载。

所以,我们在开发阶段,可以将公用库的版本设置为快照版本,而被依赖组件则引用快照版本进行开发,在公用库的快照版本更新后,我们也不需要修改pom文件提示版本号来下载新的版本,直接mvn执行相关编译、打包命令即可重新下载最新的快照库了,从而也方便了我们进行开发。

maven2中snapshot快照库和release发布库的应用相关推荐

  1. maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

    maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository. ...

  2. pom.xml 配置之:snapshot 快照库和 release发布库 的区别

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 1.如果在发布时使用 mvn deploy -P release 的命令,那么会自动使用0.1作为发 ...

  3. maven配置之:<distributionManagement>snapshot快照库和release发布库

    在使用maven过程中,我们在开发阶段经常性的会有很多公共库处于不稳定状态,随时需要修改并发布,可能一天就要发布一次,遇到bug时,甚至一天要发布N次. 我们知道,maven的依赖管理是基于版本管理的 ...

  4. pom配置之:distributionManagementsnapshot快照库和release发布库

    本文转载自:  铁木箱子的mzone的博客: http://www.mzone.cc/article/277.html http://www.mzone.cc/article/279.html 在使用 ...

  5. maven2-snapshot快照库和release发布库的应用

    在项目中应用snapshot和release库,应用snapshot和release库达到不同环境下发布不同的版本的目的,首先看一个pom文件的定义: <project><model ...

  6. maven中snapshot快照库与maven-metadata.xml

    在使用maven过程中,我们在开发阶段经常性的会有很多公共库处于不稳定状态,随时需要修改并发布,可能一天就要发布一次,遇到bug时,甚至一天要发布N次.我们知道,maven的依赖管理是基于版本管理的, ...

  7. android中裁剪压缩图片_软件发布前的库优化与裁剪:初识

    在软件发布时,都会对其裁剪.在此过程中,会先查明编译的依赖关系,并将重型的依赖库进行替换或者移除.本文将会介绍在软件发布时,库裁剪命令strip的使用,目录结构如下: CMake GraphViz查明 ...

  8. 发布库到仓库 maven jcenter JitPack MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  9. 【Gradle】管理库工程release及debug

    背景: 目前工程中是通过手动在代码中修改debug及release变量,这十分低效并且极易遗忘而造成低级错误. 需求是什么? 1.genkins上打aar包时候,直接根据genkins参数设置来决定打 ...

最新文章

  1. 【编译原理】求一个句型短语、直接短语、句柄(一看就懂~!骗小狗)
  2. mysql丢失召回_mysql笔记
  3. python定义变量并赋值_Python动态声明变量赋值代码实例
  4. 有关 Conversion to Dalvik format failed with error 1
  5. sicily 1012. Stacking Cylinders
  6. qt webkit 本地html5,Qt Webkit HTML5 Score
  7. 全国计算机统考在线模拟网站,全国计算机统考模拟试题
  8. Android——音乐播放器完善——进度条显示当前播放进度,加可拖动进度条(未待解决完问题)...
  9. 【POJ2888】Magic Bracelet Burnside引理+欧拉函数+矩阵乘法
  10. 如何使用Vegas Pro制作遮罩转场效果?
  11. 安全secuerity证券
  12. UI设计实用经验分享
  13. js下载文件 阿星小栈
  14. IOS 地图导航(其中包括苹果地图、百度地图、高德地图、谷歌地图)
  15. 数据库常考题型(2)——求候选键(候选码)
  16. Java小白学习二十八——冒泡排序
  17. 阿里云部署Django项目
  18. 网站搜索引擎优化问题
  19. 博云信创云管平台入选工信部推荐解决方案名单,头部券商信创案例获应用示范单项
  20. 如何不浪费时间-番茄工作法

热门文章

  1. [Python从零到壹] 九.网络爬虫之Selenium基础技术万字详解(定位元素、常用方法、键盘鼠标操作)
  2. Python之深入解析一行代码计算每个省面积的神器Geopandas
  3. 并发编程——线程——理论知识
  4. PaddlePaddle训练营——公开课——AI核心技术掌握——第2章机器能“看”的现代技术——源自视觉神经原理的卷积网络简介及深入理解
  5. Vue.js项目新建及目录结构分析
  6. linux下常用快捷键
  7. ubuntu16.04下安装有道词典
  8. 【Linux网络编程】UDP编程
  9. 【Linux系统编程】进程间通信--无名管道(pipe)
  10. 什么用于创建python与数据库之间的链接_python3连接数据库用什么