参考了网络上很多文章, 特此感谢.

Maven项目规范

  • 同一项目中所有模块版本保持一致
  • 子模块统一继承父模块的版本
  • 统一在顶层模块Pom的节中定义所有子模块的依赖版本号,子模块中添加依赖时不要添加版本号
  • 开发测试阶段使用SNAPSHOT
  • 生产发布使用RELEASE或(无后缀)正式版
  • 新版本迭代只修改父POM中的版本和子模块依赖的父POM版本

部署目标

  • 正确
  • 快速
  • 简单
  • 自动

善用工具

  • 插件 versions-maven-plugin: 管理自身版本号, 依赖版本号
  • 插件 maven-release-plugin: 自动升级版本, 提交代码, 打TAG

场景1: 独立项目(对外)的发布流程

  • 确定/更新依赖模块版本(第三方)
  • 发布服务器: 更新代码
  • 准备发布: mvn -B -DskipTests=true release:clean release:prepare
    • 本地准备: 修改版本号从snapshot到无后缀版本(或自定义)
    • 本地准备: GIT仓库的新TAG: bfeaturemod-1.0.8
    • 本地编译
    • 本地准备: 更新版本号为下一个snapshot版本
    • 本地准备: 提交
  • 正式发布: mvn -DskipTests=true release:perform
  • 发布最新的snapshot版本: mvn -DskipTests=true deploy

场景2: 内部项目永远snapshot

内部项目就很灵活了, 这里介绍一种发布流程.

前提条件

  • 所有项目版本号永远是snapshot, 而且一般不升版本号, 为1.0-snapshot
  • 生产仓库和开发仓库物理隔离
  • 如果只有一台部署机器, 则只使用mvn install, 不使用deploy
  • 每次发布都是全量发布(如果代码没有修改, 部署脚本(自己编写)会比较后自动跳过)
  • 配置好依赖关系后, 会自动先compile和install依赖 (自己编写的部署脚本)
  • 父子模块可以分别compile和install (被依赖的话会自动编译安装)

备注: 如果多台部署机器, 则需要deploy, 则需要激活Maven仓库的profile (区分生产和开发)

内部项目部署—发布步骤

  • 如果有依赖项目, 则先发布依赖项目(人工或者脚本根据配置)
  • 更新代码, 检查代码是否有更新, 如果没有更新则不发布
  • 编译发布 mvn clean install –DskipTests=true
  • 打TAG提交到GIT
  • 部署: 复制包到远程服务器, stop/start

内部项目部署—支持的方式

  • Web (jetty)
  • Service(Assembly) +使用wrapper包装
  • Spring Boot + Wrapper
  • Command 自定义
  • 自己扩展

需要自己准备脚本(复制粘贴), 依赖配置等(一次性)

内部项目部署配置—示例

场景3: 更复杂的项目开发部署

可以组合使用versions-maven-plugin , maven-release-plugin 来自动发布, 但会比较繁琐.

过于复杂, 则不推荐使用了.

总之要根据自己的实际情况做调整, 或者使用更好的工具更好的方法来解决.

Maven项目思考&实战的更多相关文章

  1. 【IDEA】本地新建Maven项目+配置Git和GitHub+代码上传和拉取到GitHub+其他IDEA和GitHub实战

    一.本地新建Maven项目并启动成功 1. 按照IDEA提供的模板,构建一个maven webapp的模板项目. 一路Next,到最后的finish.如下图. 2. 新建Tomcat,启动刚建立的项目 ...

  2. 《maven实战》笔记(2)----一个简单maven项目的搭建,测试和打包

    参照<maven实战>在本地创建对应的基本项目helloworld,在本地完成后项目结构如下: 可以看到maven项目的骨架:src/main/java(javaz主代码)src/test ...

  3. kubernetes下jenkins实战maven项目编译构建

    关于kubernetes环境的jenkins集群 在kubernetes环境部署的jenkins集群,执行任务时会新建pod,任务完成后pod被销毁,架构如下所示: 在kubernetes搭建jenk ...

  4. Maven实战(二)构建简单Maven项目

    上一节讲了maven的安装和配置,这一节我们来学习一下创建一个简单的Maven项目 1. 用Maven 命令创建一个简单的Maven项目 在cmd中运行如下命令: mvn archetype:gene ...

  5. Maven实战(三)Eclipse构建Maven项目

    1. 安装m2eclipse插件    要用Eclipse构建Maven项目,我们需要先安装meeclipse插件    点击eclipse菜单栏Help->Eclipse Marketplac ...

  6. (转)Maven实战(三)Eclipse构建Maven项目

    1. 安装m2eclipse插件    要用Eclipse构建Maven项目,我们需要先安装meeclipse插件    点击eclipse菜单栏Help->Eclipse Marketplac ...

  7. (转)Maven实战(二)构建简单Maven项目

    上一节讲了maven的安装和配置,这一节我们来学习一下创建一个简单的Maven项目 1. 用Maven 命令创建一个简单的Maven项目 在cmd中运行如下命令: mvn archetype:gene ...

  8. 096实战 在windows下新建maven项目

    1.拷贝settings到.m2文件下 2.修改文件 3.新建Project项目 4.转换为maven项目 config下转换 5.拷贝pom文件 <project xmlns="ht ...

  9. 【Maven实战技巧】「插件使用专题」Maven-Archetype插件创建自定义maven项目骨架

    技术推荐 自定义Archetype Maven骨架/以当前项目为模板创建maven骨架,可以参考http://maven.apache.org/archetype/maven-archetype-pl ...

随机推荐

  1. Java语言实现二维码的生成

    众所周知,现在生活中二维码已经是无处不见.走在街道上,随处可见广告标语旁有二维码,手机上QQ,微信加个好友都能通过二维码的方式,我不知道是什么时候兴起的二维码浪潮,但是我知道,这在我小时候可是见不到的 ...

  2. kafka简单介绍

    Kafka是分布式发布-订阅消息系统.它最初由LinkedIn公司开发,之后成为Apache项目的一部分.Kafka是一个分布式的,可划分的,冗余备份的持久性的日志服务.它主要用于处理活跃的流式数据. ...

  3. 关于LCA的几点想法

    倍增 这是最最最常见的写法了,一个fa[N][logN]的数组直接搞定 时间复杂度也不算太高 预处理 $ O(nlogn) $ 如果你想卡的话,可以卡到 $ O(nlogh) $ h为树的深度 查询 ...

  4. 堆&&优先队列&&TreeMap

    题目描述 5710. 积压订单中的订单总数 题解 题目不难,主要是要读懂题意,一步步模拟,代码较长,需要细心检查. 坑较多,比如我犯了很多傻逼问题:想都不想就拿1<<9+7当作100000 ...

  5. 巧用SpringBoot扩展点EnvironmentPostProcessor

    我们的项目是单体项目,使用的是springboot的框架,随着对接的外部服务越来越多,配置文件越来越臃肿..我们将对接的外部服务的代码单独抽离出来形成service依赖,之后以jar包的形式引入,这时 ...

  6. Python字符串格式方式 %s format()

    p.p1 { margin: 0; font: 12px ".PingFang SC" } p.p2 { margin: 0; font: 12px "Helvetica ...

  7. 安卓开发--探究碎片Fragment

    简述: 最近做开发的时候又遇到了Fragment,发现太久没写,都快忘了,就抓紧写个笔记(我太懒的了233) Fragment可以简单的看成迷你的活动,它和活动一样都有布局和生命周期,它可以嵌入活动之 ...

  8. Linux 内核睡眠的几种方式

    译至:http://geeki.wordpress.com/2010/10/30/ways-of-sleeping-in-linux-kernel/ 在Linux中睡眠有2-3种不同的方法. 睡眠的第 ...

  9. fast-poster海报生成器v1.4.0,一分钟完成海报开发

    fast-poster海报生成器v1.4.0,一分钟完成海报开发 介绍 一个快速开发动态海报的工具 在线体验:https://poster.prodapi.cn/ v1.4.0 新特性 为了项目和团队 ...

  10. ROS2学习之旅(2)——配置ROS2环境

    目录 1.source一下setup文件 2.自动source 3.自动进入工作区(不常用) 4.检查环境变量是否设置成功 5.总结 ROS2依赖于使用shell(终端)环境组合工作空间的概念.工作空 ...