华为云高红霞:CBC微服务代码重构独立发布实践

2024-01-25 15:50

本文主要是介绍华为云高红霞:CBC微服务代码重构独立发布实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

bb597d2c42e85b108243d2d60842babd.gif

嘉宾 | 高红霞   整理 | 黄引红

出品 | CSDN云原生

2022年6月9日,在CSDN云原生系列在线峰会第8期"华为云云原生实践与应用峰会"上,华为云数字化平台技术专家高红霞分享了华为CBC微服务代码重构与独立发布的实践案例。

戳👇观看高红霞分享视频

CBC(Cloud Business Center)云运营平台,负责华为云的交易平台和运营平台能力,涵盖官网、订单、计费、CRM、伙伴云等业务模块,涉及上百个微服务。CBC可以理解为是一个大的集群,各个集群之间由统一的服务进行注册、发行和管理。

CBC的建设目标是:实现服务自治,提升服务可维护性、可扩展性,需求可独立上线,不用齐步走。

a9a6929573a6c02ec75694a0a058e26b.png

CBC遇到的问题

但在实践过程中,我们遇到了一些问题:

  • CBC存在一些不好管理的“超级微服务”,划分的定义为:拥有100+的接口(API),10W+行代码的微服务

  • 服务中,有些接口和信息的变化相对比较频繁,有些十分稳定,虽在同一个服务管理中,但变更节奏不一致

  • 领域模型划分不清晰,存在散弹式修改,修改一个问题却引入新问题等情况

  • CBC版本采用火车模式(集成发布部署),所有微服务按照特定节奏交付(1个月2个版本),一起联调、一起上线,部分需求TTM被拉长

之所以存在这些问题,我们是这样分析的:

  • 领域模糊:在重构之前,因为采用的是统一部署,所以我们比较少关注领域模型

  • 接口随意:关键领域的模糊,导致接口设计很随意。重构之前有一个超级微服务,有300多个接口,接口相互覆盖,没有统一的设计原则

  • 数据泥团:因为接口随意开放,导致数据的关系不清晰

  • 代码杂糅:重构之前,所有的数据都在同一个服务当中,不同流程均可以直接访问、使用这些数据,接口的复用度低,维护成本高。不清晰的数据关系反映在代码层次,杂糅重构之前,代码当中除了接口层,其他的层次几乎是不存在的

  • 依赖复杂:因为代码杂糅导致依赖和被依赖的关系都很复杂,重构前几乎大部分服务依赖如何使用和调用的都不清楚,调用其他服务的代码散落、难以管理,因为依赖复杂,所以所有的服务都只能齐步走

  • 低效率部署:重构之前,两周一次的火车版本统一上线,导致了部署低效

  • 部署平台不支持单一微服务的分流测试

  • UT写得很少也比较难写

  • 散弹式修改:牵一发而动全身

为了解决这些问题,我们进行了服务重构、工程能力提升等多方面尝试,建立了微服务独立发布体系结构,最终实现了服务可自定节奏独立发布部署上线,解决了服务可维护性、可扩展性,提升了交付效率,降低了服务学习、维护、测试成本。

9ff53842ee0583117885503a4268e443.png

下面重点介绍其中的服务重构、工程能力提升两部分实践。

34113ee99e747c0fc9848fd7363b2266.png

服务重构

一、领域驱动设计:DDD大尺度的上下文划分&领域建模

目标:通过领域模型划分,实现业务模块解耦,减少散弹式修改

措施:

  • 按照业务边界进行大尺度的上下文划分,识别多变的和稳定的模块

  • 梳理上下文之间的依赖关系,建立领域模型,为代码架构做输入

117bad664a3a6a9785cb93e2aca07a61.png

二、代码解耦——代码的整洁架构

目标:重构完成后,保证可靠性和灵活性

措施:

  • 引入DDD整洁架构思想,分为入口/出口、业务编排层、领域层

  • 实行“旧的不变,新的创建;一步切换,旧的再见”的重构手法

  • 引入架构测试,保证架构的稳定;新代码不会冲破已有架构

  • 提升白盒测试的覆盖率,降低白盒测试的编写难度

c633a1343f234350004c4f48672210be.png

三、API治理——根据领域模型进行接口的精简、整合

措施:

  • 按领域模型划分,将非本领域范围内的接口剥离

  • 按特性进行归类,对相同功能特性的接口进行整合,从通用、可扩展、兼容、安全等方面合理设计接口

  • 定期审视和总结回顾,确保接口整合工作遵循“分析->规划->整改->下线”有序开展,持续改进和完善整合过程中的问题,形成良性循环

经过以上服务重构措施,初步实现了一些效果。

ecf9ef657b82aaa48ff83cd790d70622.png

e56f699562062cba06f56106ba5a0ae2.png

工程能力提升

一、设计微服务独立发布部署流程

通过独立发布流水线、微服务级蓝绿部署能力构建,实现微服务特性E2E独立发布部署,保障特性上线质量和效率,同时降低版本火车模式下多分支同步和维护成本。

  • 效果1:服务当前支持高低版本并存,同时承载流量

  • 效果2:CBC实现基于用户名单和用户比例的引流验证能力

二、独立发布部署过程(金丝雀+微服务级蓝绿部署)

6f7e198f60c4b9490357b6d9f9f90616.jpeg

三、DevOps流程中测试能力的适配与改造

目标:建设微服务测试规范、能力,保障微服务独立部署质量不下降。

  • 变更的开发分支并行开发

  • API用例多个变更一起测试

  • 有实时接口测试评估能力

  • 微服务可以自行进行DFX测试

  • 微服务允许进行特性级的测试

措施:

  • 不同开发分支的接口设计可独立进行

  • 落地多个变更一起测试的能力

  • 开发接口测试评估流水线插件

  • 开发微服务级别的DFX测试能力和流水线插件

  • 定义并部署微服务特性级测试环境

ea9deb1c5db77abacf7869faf0172e97.png

总结:实践可复制DNA

  • 通过DDD整洁架构思想将服务进行上下文划分、领域建模和层次划分,保证不同业务模块不互相侵入,同时维持架构稳定。引入ArchUnit架构测试看护代码架构

  • 支持按微服务蓝绿引流,支持各服务进行微服务蓝绿引流独立测试,不被其他服务的微服务蓝绿引流干扰

  • API用例可匹配独立部署模式下多个变更一起发布部署场景的测试;有微服务的实时接口测试评估的能力

6ad0da653538d5e75f5c3698845025e0.png

END

云原生志愿者计划正在招募🔥

精准把握技术趋势,深度学习新技术、新实践

3e413841557650c74d5c69efeb58433d.jpeg扫描图片二维码立即申请加入

 
 
 

— 推荐阅读 —

☞京东科技马俊昌:微服务低代码平台“星链”应用实践☞听云研发总监杨金全:以Tracing为核心的可观测性体系
☞云原生应用交付的前世今生与一线实践☞2个维度5大方法,让你的微服务在K8s上跑起来☞透彻解析云原生在数字化转型中的应用实践,PaaS功不可没

点这里↓↓↓记得关注标星哦

 
一键三连 「分享」「点赞」「在看」
成就一亿技术人

这篇关于华为云高红霞:CBC微服务代码重构独立发布实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/643767

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

定价129元!支持双频 Wi-Fi 5的华为AX1路由器发布

《定价129元!支持双频Wi-Fi5的华为AX1路由器发布》华为上周推出了其最新的入门级Wi-Fi5路由器——华为路由AX1,建议零售价129元,这款路由器配置如何?详细请看下文介... 华为 Wi-Fi 5 路由 AX1 已正式开售,新品支持双频 1200 兆、配有四个千兆网口、提供可视化智能诊断功能,建

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

TP-Link PDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务

《TP-LinkPDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务》近期,路由器制造巨头普联(TP-Link)在用户群体中引发了一系列重要变动,上个月,公司发出了一则通知,明确要求所... 路由器厂商普联(TP-Link)上个月发布公告要求所有用户必须完成实名认证后才能继续使用普联提供的 D

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加