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

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. Redmine部署中遇到的问题

    Redmine部署文章: 第一篇:Redmine部署 第二篇:Redmine部署中遇到的问题 上一篇文章我写了Redmine怎样部署(点这里直达上一篇文章),这一篇就写一下在Redmine部署中遇到过 ...

  2. 66.QT-线程并发、QTcpServer并发、QThreadPool线程池

    1.线程并发一个程序内部能拥有多个线程并行执行.一个线程的执行可以被认为是一个CPU在执行该程序.当一个程序运行在多线程下,就好像有多个CPU在同时执行该程序.总之,多线程即可以这么理解:多线程是处理 ...

  3. 21、oracle打开和关闭归档日志的方法

    21.1.介绍: 在实际应用中,我们需要实现对数据的备份,其实现方式主要有冷备份和热备份两种,现在我们主要讨论热备份的具体操作. 热备份也称为联机备份,在数据库的存档模式下进行备份,oracel数据库 ...

  4. FlowNet:simple / correlation 与 相关联操作

    Flow Net : simple / correlation 与 相关联操作 ​ 上一篇文章中(还没来得及写),已经简单的讲解了光流是什么以及光流是如何求得的.同时介绍了几个光流领域的经典传统算法. ...

  5. Redis 底层数据结构之跳跃表

    文章参考 <Redis 设计与实现>黄建宏 Redis(2) 跳跃表 跳跃表 跳跃表 skiplist 是一种有序数据结构,它通过在每个节点中维持多个指向其他节点的指针,从而达到快速访问节 ...

  6. redis学习笔记(二)——java中jedis的简单使用

    redis怎么在java中使用,那就是要用到jedis了,jedis是redis的java版本的客户端实现,原本原本想上来就直接学spring整合redis的,但是一口吃个胖子,还是脚踏实地,从基础开 ...

  7. buu 新年快乐

    一.查壳 发现是upx的壳. 二.拖入ida,发现要先脱壳. 题外话.总结一下手动脱壳,esp定律: 1.先单步到只有esp红色时,右键数据窗口跟随. 2.到数据窗口后,左键硬件访问,byte和wor ...

  8. 每日英语——the rest of my life

    <the rest of My life> 词面意思:我的余生 实际意思:我的余生 1.  歌曲:<The Rest of My life> Less Than Jake 歌词 ...

  9. C语言:最大公约数和最小公倍数

    #include <stdio.h> int main() { int a,b,c,m,t; printf("请输入两个数:\n"); scanf("%d%d ...

  10. NB-IoT物联网连接

    一.NB-1oT的专有能力物联网(Internet of Things).简称IoTNB-IoT就是指窄带物联网(Narrow Band-Internet of Things)技术目前关于NB-IoT ...