总结:生产环境Release、Snapshot两种包版本该如何管理与发布构建

总结:生产环境release、snapshot两种包版本该如何管理与发布构建

  • 一·Release、Snapshot两种包该如何分别管理与发布构建呢?
    • [1. 核心开关:版本号命名](#1. 核心开关:版本号命名)
    • [2. 如何发布构建 (Deploy)](#2. 如何发布构建 (Deploy))
    • [3. 如何管理依赖拉取 (Dependency)](#3. 如何管理依赖拉取 (Dependency))
    • [4. 推荐的规范化研发流程(最佳实践)](#4. 推荐的规范化研发流程(最佳实践))

一·Release、Snapshot两种包该如何分别管理与发布构建呢?

在 Maven 中,Release(正式版)和 Snapshot(快照/开发版)的管理与发布,核心完全依赖于 版本号()的命名规范,Maven 底层会根据版本号的后缀自动进行路由和策略处理。

具体来说,你可以通过以下几个方面来分别管理和发布这两种包:

1. 核心开关:版本号命名

Maven 识别包类型的唯一标准是:版本号是否以 -SNAPSHOT(必须全部大写)结尾。

Snapshot 版本:例如 1.0.0-SNAPSHOT。代表这是一个处于开发中、不稳定的版本。

Release 版本:例如 1.0.0 或 1.0.0-RELEASE。只要不带 -SNAPSHOT,Maven 均视其为稳定的正式版。

2. 如何发布构建 (Deploy)

当你执行 mvn deploy 命令进行构建并推送到私服时,你不需要手动指定推送到哪个仓库,Maven 会自动根据版本号判断:

(1)发布 Snapshot: 当前版本号带有 -SNAPSHOT,Maven 会自动找到 下的 配置,将其上传到 libs-snapshots-local 仓库。由于是快照,私服会自动在原包名后追加时间戳(如 1.0.0-20231010.1230),允许多次覆盖发布。

(2)发布 Release: 当前版本号剔除了 -SNAPSHOT,Maven 会自动找到 下的 配置,将其上传到 libs-releases-local 仓库。注意:Release 仓库通常具备只读属性,同版本号的 Release 包一旦发布,就严禁再次覆盖上传。

xml 复制代码
//项目发布/上传配置
<distributionManagement>
        <repository>
            <id>libs-releases</id>
            <url>
                http://xxx/xxx
            </url>
        </repository>
        <snapshotRepository>
            <id>libs-snapshots</id>
            <name>xxx repository-snapshots</name>
            <url>http://xxx/xxx</url>
        </snapshotRepository>
    </distributionManagement>

//依赖库下载源配置
    <repositories>
        <repository>
            <snapshots>
                <enabled>true</enabled>
            </snapshots>
            <id>xxx-central</id>
            <name>libs-releases</name>
            <url>http://xxx/xxx</url>
        </repository>

        <repository>
            <snapshots />
            <id>snapshots</id>
            <name>libs-snapshots</name>
            <url>http://xxx/xxx</url>
        </repository>
    </repositories>

3. 如何管理依赖拉取 (Dependency)

当你的其他项目需要引入这两个包时,Maven 的本地缓存机制对这两种包采取了截然不同的管理策略:

(1)管理 Release 包: 一旦本地 Maven 仓库(.m2 目录)下载了 1.0.0 版本的 Release 包,就永远不会再去远程仓库检查更新了。这保证了生产环境依赖的绝对稳定性。
(2)管理 Snapshot 包: 如果你依赖了 1.0.0-SNAPSHOT,Maven 知道这个版本会频繁更新。默认情况下,Maven 每天会去私服检查一次有没有最新的时间戳快照;如果你急需拉取同事刚推上去的代码,可以在执行构建命令时加上 -U 参数(例如 mvn clean compile -U),强制 Maven 立即去私服拉取最新的 Snapshot 覆盖本地代码。

4. 推荐的规范化研发流程(最佳实践)

在实际的企业级项目迭代中,我们通常这样配合使用:
日常开发阶段: 大家都在特性分支开发,把版本号改为 1.0.0-SNAPSHOT,随时可以 mvn deploy,团队成员通过快照频繁互相同步最新的 API 和代码。

发版/上线阶段: 准备上线前,修改 pom.xml,将版本号去掉 -SNAPSHOT,改为 1.0.0。提交代码,并在 Git 上打一个 v1.0.0 的 Tag。通过 CI/CD 流水线执行打包,将这个稳定的代码 deploy 到 Release 仓库供线上服务使用。

发版完成后: 立马修改 pom.xml,将版本号升级为下一个版本的快照,例如 1.0.1-SNAPSHOT,为下一个迭代做准备。

(注:如果你觉得手动改版本号太麻烦,业界通常会使用 versions-maven-plugin 插件的 mvn versions:set -DnewVersion=xxx 命令,或者配合 CI/CD 平台的脚本来自动修改与发布。)

相关推荐
yangminlei1 小时前
Spring Boot Starter自定义开发 构建企业级组件库
java·spring boot·后端
牛奶咖啡131 小时前
CI/CD——在jenkins中构建流程实现springboot项目的自动化构建与部署
java·ci/cd·k8s·jenkins·springboot·springboot制作镜像·使用源码项目制作镜像
桔筐1 小时前
Redis 无锁化库存扣减方案(INCR + SETNX 实现,高并发不超卖)
java·redis
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题 第44题】【JVM篇】第4题:什么时候会触发 Young GC?什么时候会触发 Full GC?
java·开发语言·jvm·后端·面试
Zephyr_01 小时前
SQL,MyBatis-Plus,maven,Spring与VUE3
sql·spring·vue·maven·mybatis
小妖6661 小时前
js 实现python的SortedList有序集合
java·javascript·python
梦梦代码精1 小时前
电商系统的核心难点:订单与营销系统如何设计?——LikeShop 架构深度拆解(规则计算与状态一致性)
java·开发语言·低代码·架构·开源·github
SZLSDH1 小时前
专项治理场景下,数字孪生IOC的架构适配逻辑:以智慧河湖监管为例
java·大数据·架构·数据可视化
隐退山林1 小时前
JavaEE进阶:SpringBoot日志
java·开发语言