活动介绍

高级持续交付实践指南

立即解锁
发布时间: 2025-08-24 02:19:39 阅读量: 1 订阅数: 4
# 高级持续交付实践指南 ## 1. 非向后兼容变更处理 非向后兼容的数据库变更处理起来要困难得多。例如,如果数据库变更 v11 是非向后兼容的,那么将服务回滚到 1.2.7 版本就会变得不可能。为了解决这个问题,我们可以将非向后兼容的变更转换为在一定时间内向后兼容的变更,具体做法是将模式迁移拆分为两个部分: - **立即执行的向后兼容更新**:通常意味着保留一些冗余数据。 - **在回滚期之后执行的非向后兼容更新**:回滚期定义了我们可以将代码回退的范围。 ### 1.1 删除列的示例 以删除列为例,具体步骤如下: 1. **停止在源代码中使用该列**(v1.2.5,向后兼容更新,首先执行)。 2. **从数据库中删除该列**(v11,非向后兼容更新,在回滚期之后执行)。 在数据库 v11 之前的所有服务版本都可以回滚到任何先前版本,而从服务 v1.2.8 开始的服务只能在回滚期内回滚。这种方法虽然看似只是延迟了列的删除,但它解决了回滚和零停机部署的问题,降低了发布风险。如果将回滚期设置为合理的时间,例如每天多次发布的情况下设置为两周,那么风险可以忽略不计。 ### 1.2 重命名列的示例 以计算器服务中重命名 `result` 列到 `sum` 为例,具体步骤如下: 1. **向数据库中添加新列**:创建 `src/main/resources/db/migration/V3__Add_sum_column.sql` 迁移文件,内容如下: ```sql alter table CALCULATION add SUM varchar(100); ``` 执行迁移后,数据库中将有 `result` 和 `sum` 两列。 2. **修改代码以使用两列**:在 `Calculation` 类中进行修改,代码如下: ```java public class Calculation { ... private String sum; ... public Calculation(String a, String b, String sum, Timestamp createdAt) { this.a = a; this.b = b; this.sum = sum; this.result = sum; this.createdAt = createdAt; } public String getSum() { return sum != null ? sum : result; } } ``` 从现在起,每次向数据库中添加一行时,相同的值会同时写入 `result` 和 `sum` 列。读取 `sum` 时,首先检查新列中是否存在该值,如果不存在则从旧列中读取。也可以使用数据库触发器来实现相同的效果。到目前为止,所有的更改都是向后兼容的,因此我们可以随时将服务回滚到任何版本。 3. **合并两列中的数据**:在发布稳定一段时间后执行,创建 `V4__Copy_result_into_sum_column.sql` 迁移文件,内容如下: ```sql update CALCULATION set CALCULATION.sum = CALCULATION.result where CALCULATION.sum is null; ``` 此时回滚仍然没有限制,但如果需要部署步骤 2 更改之前的版本,则需要重复此数据库迁移。 4. **从代码中移除旧列**:由于新列中已经包含了所有数据,因此可以在数据模型中不再使用旧列。修改 `Calculation` 类,移除与 `result` 相关的代码,如下所示: ```java public class Calculation { ... private String sum; ... public Calculation(String a, String b, String sum, Timestamp createdAt) { this.a = a; this.b = b; this.sum = sum; this.createdAt = createdAt; } public String getSum() { return sum; } } ``` 此操作仅在步骤 2 之前是向后兼容的,如果需要回滚到步骤 1,可能会丢失此步骤之后存储的数据。 5. **从数据库中删除旧列**:在回滚期之后执行,确保不会回滚到步骤 4 之前。创建 `V5__Drop_result_column.sql` 迁移文件,内容如下: ```sql alter table CALCULATION drop column RESULT; ``` 完成此步骤后,列重命名过程结束。这种方法虽然使操作稍微复杂,但降低了非向后兼容数据库变更的风险,实现了零停机部署。 ## 2. 分离数据库更新和代码变更 之前我们通常将数据库迁移与服务发布一起执行,即每次提交(意味着每次发布)都包含数据库变更和代码变更。但推荐的做法是明确分离,即提交到仓库的要么是数据库更新,要么是代码变更。 ### 2.1 分离的好处 数据库 - 服务变更分离的好处是可以免费进行向后兼容性检查。例如,假设变更 v11 和 v1.2.7 涉及一个逻辑变更,如向数据库中添加新列。我们首先提交数据库 v11,持续交付管道中的测试会检查数据库 v11 是否与服务 v.1.2.6 兼容,即检查数据库更新 v11 是否向后兼容。然后提交 v1.2.7 变更,管道会检查数据库 v11 是否与服务 v1.2.7 正常工作。 ### 2.2 分离的实践 数据库 - 代码分离并不意味着必须有两个单独的 Jenkins 管道,管道可以同时执行两者,但应保持每次提交要么是数据库更新要么是代码变更的良好实践。总之,数据库模式变更不应手动进行,而应使用迁移工具自动化执行,并作为持续交付管道的一部分。同时,应避免非向后兼容的数据库更新,最好的方法是将数据库和代码变更分别提交到仓库。 ## 3. 避免共享数据库 在许多系统中,数据库成为多个服务共享的中心点。这种情况下,对数据库的任何更新都会变得更具挑战性,因为需要在所有服务之间进行协调。 ### 3.1 共享数据库的问题 以在线商店为例,`Customers` 表包含 `first name`、`last name`、`username`、`password`、`email` 和 `discount` 列,有三个服务对客户数据感兴趣: - **Profile manager**:用于编辑用户数据。 - **Checkout processor**:处理结账(读取用户名和电子邮件)。 - **Discount manager**:分析客户订单并设置合适的折扣。 这些服务依赖于相同的数据库模式,存在以下问题: - **更新兼容性**:更新模式时,必须确保与所有三个服务兼容。虽然所有向后兼容的变更没问题,但任何非向后兼容的更新都会变得非常困难甚至不可能。 - **管道选择**:每个服务都有单独的交付周期和持续交付管道,那么应该使用哪个管道进行数据库模式迁移呢?这个问题没有很好的答案。 ### 3.2 解决方案 为了解决这些问题,每个服务应该有自己的数据库,并且服务之间通过 API 进行通信。例如,`Checkout processor` 应该通过 `Profile manager` 的 API 获取客户数据,`discount` 列应该提取到单独的数据库(或模式)中,由 `Discount manager` 负责管理。这种方法符合微服务架构原则,通信通过 API 比直接访问数据库更灵活。在单体系统中,数据库通常是集成点,但这种方法会
corwn 最低0.47元/天 解锁专栏
赠100次下载
继续阅读 点击查看下一篇
profit 400次 会员资源下载次数
profit 300万+ 优质博客文章
profit 1000万+ 优质下载资源
profit 1000万+ 优质文库回答
复制全文

相关推荐

SW_孙维

开发技术专家
知名科技公司工程师,开发技术领域拥有丰富的工作经验和专业知识。曾负责设计和开发多个复杂的软件系统,涉及到大规模数据处理、分布式系统和高性能计算等方面。
最低0.47元/天 解锁专栏
赠100次下载
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
千万级 优质文库回答免费看

最新推荐

【DB文件查看器进阶手册】:掌握这些高级功能,提升查看效率

![DB文件怎么打开—DB文件查看器](https://media.geeksforgeeks.org/wp-content/uploads/Capture-55.jpg) # 摘要 本文详细介绍了DB文件查看器的基础概念、核心功能以及高级操作和应用技巧。首先,阐述了DB文件查看器的基本架构和文件结构,进而深入解析了其数据检索、展示及导出的核心技术。文章还探讨了编辑、更新记录和索引管理等高级操作,以及自动化任务、数据迁移和安全性方面的应用技巧。通过实践案例分析,本文展示了DB文件查看器在大型数据库管理和复杂查询中的应用效果,并提供了常见问题的诊断与解决策略。最后,展望了DB文件查看器在云计算

【STID135开发板项目实践】:构建与管理的最佳策略

![dm00136028.zip_STID135_STID135开发板_dm00136028_zip](https://res.cloudinary.com/rsc/image/upload/b_rgb:FFFFFF,c_pad,dpr_2.625,f_auto,h_214,q_auto,w_380/c_pad,h_214,w_380/R9173762-01?pgw=1) # 摘要 本文详细介绍了STID135开发板的概述、特性、开发环境搭建、编程实践及项目构建案例。首先,本文对STID135开发板的硬件组件和特性进行了概述,并探讨了如何搭建与配置开发环境。接着,文章深入解析了基于STID1

【STM32CubeIDE代码补全完全教程】:成为STM32开发专家的终极学习路径

![【STM32CubeIDE代码补全完全教程】:成为STM32开发专家的终极学习路径](https://reversepcb.com/wp-content/uploads/2023/05/STM32CubeMX-Configuration-Perspective.png.webp) # 摘要 随着嵌入式系统开发的普及,STM32CubeIDE作为一种集成开发环境,其代码补全功能在提升开发效率和代码质量方面扮演着重要角色。本文首先介绍了STM32CubeIDE的基本概念及安装流程,随后深入探讨了代码补全的理论基础、实践应用和性能优化。特别地,本文分析了代码补全如何与STM32开发实践相结合,

老冀文章编辑工具v1.8高级技巧分享:挖掘工具深层次潜力的10大方法

![老冀文章编辑工具v1.8高级技巧分享:挖掘工具深层次潜力的10大方法](https://bkimg.cdn.bcebos.com/pic/5366d0160924ab18ea978d313cfae6cd7b890b36) # 摘要 老冀文章编辑工具v1.8提供了全面的编辑和格式化功能,旨在提升用户的内容创作与管理效率。本文首先对编辑工具的核心功能进行概览,并详细解析了其高级特性,包括用户界面定制化、内容管理、格式化工具以及扩展插件系统。接着,文章分享了实战技巧,探讨如何通过快速导航、批量编辑以及自定义脚本与自动化来进一步提高编辑效率。针对高级用户可能遇到的问题,本文还讨论了插件冲突的排除

固件更新风险评估与减轻策略:系统停机的最小化

![固件更新风险评估与减轻策略:系统停机的最小化](https://montemagno.com/content/images/2021/09/Screen-Shot-2021-09-06-at-7.59.46-AM.png) # 摘要 固件更新作为维护设备安全性与性能的重要手段,在技术快速发展的今天显得尤为重要,但同时伴随着风险和挑战。本文深入探讨了固件更新过程中的风险评估、控制点识别、系统停机成本及影响,并通过实践案例分析了成功与失败的固件更新经验。针对固件更新风险,文章提出了一系列减轻策略,包括风险预防措施、自动化更新流程、持续集成策略以及用户教育和技术支持的重要性。最后,本文展望了固

【GIS地图制图精要】:打造专业级别的内蒙古水系分布图

![【GIS地图制图精要】:打造专业级别的内蒙古水系分布图](https://www.nicoladeinnocentis.it/sito/wp-content/uploads/2017/10/georeference.png) # 摘要 本文全面探讨了地理信息系统(GIS)在地图制图中的应用,涵盖了从数据获取到制图实践操作的整个流程。文章首先介绍了GIS的基础知识以及地图制图的基本概念。随后,针对内蒙古水系数据的获取、预处理、清洗和质量控制进行了详细讨论,并比较了当前流行的GIS软件及其制图功能。在分析和制图方面,文章深入探讨了水文地理学的应用、专题制图技术和动态变化分析方法。实践操作章节

Brocade MIBs网络带宽管理:基于MIBs的监控与控制策略详解

![Brocade MIBs网络带宽管理:基于MIBs的监控与控制策略详解](https://substackcdn.com/image/fetch/w_1200,h_600,c_fill,f_jpg,q_auto:good,fl_progressive:steep,g_auto/https%3A%2F%2Fsiteproxy.ruqli.workers.dev%3A443%2Fhttps%2Fsubstack-post-media.s3.amazonaws.com%2Fpublic%2Fimages%2F400e92f8-7e84-4ba6-9443-74368c1eaeb6_3735x3573.jpeg) # 摘要 本文综述了Brocade MIBs在网络带宽管理中的应用,

持续集成与部署(CI_CD)实施:S12(X)项目管理秘诀

![持续集成与部署(CI_CD)实施:S12(X)项目管理秘诀](https://www.edureka.co/blog/content/ver.1531719070/uploads/2018/07/CI-CD-Pipeline-Hands-on-CI-CD-Pipeline-edureka-5.png) # 摘要 随着软件开发速度的加快,持续集成与持续部署(CI/CD)已成为企业确保快速交付高质量软件的关键实践。本文深入探讨了CI/CD的核心概念、工具选择与技术实践,并结合S12(X)项目的案例分析了CI/CD的实施细节。文中详细阐述了CI/CD工具的分类与特点,流水线设计原则以及环境配置

BCM5396日志分析与故障诊断:掌握日志管理,快速定位问题

# 摘要 本文围绕BCM5396日志分析与故障诊断的核心议题展开,首先概述了日志分析与故障诊断的基本概念,随后深入探讨了日志数据的类型、结构、收集、存储、安全性和合规性管理。紧接着,文中介绍了多种日志分析工具及其实践应用,包括模式匹配、日志聚合、排序和可视化技术,并通过实际案例分析展示了日志分析在故障诊断和性能优化中的重要性。文章进一步详细阐述了故障诊断的流程、工具和策略,并对故障案例进行了深入分析,提出了解决方案及预防措施。最后,本文探讨了日志管理的最佳实践以及故障预防和持续改进方法,旨在为网络管理和故障排除提供指导和参考。 # 关键字 BCM5396;日志分析;故障诊断;数据管理;安全合

【飞行模拟器的自动化测试】:实现F-16模拟配平的自动化校准,效率倍增!

![【飞行模拟器的自动化测试】:实现F-16模拟配平的自动化校准,效率倍增!](https://d3i71xaburhd42.cloudfront.net/d30c440a618b1e4e9e24152ae112553108a7a48d/24-Figure4.1-1.png) # 摘要 本文对飞行模拟器自动化测试进行了全面概述,探讨了自动化测试的理论基础、F-16模拟配平自动化校准的实现、自动化校准测试的深度应用与优化,以及未来展望。自动化测试不仅提高了测试效率和准确性,还降低了人力成本。针对F-16模拟配平,文章详细介绍了自动化校准脚本的设计、开发、测试与部署,并分析了校准测试数据,提出了