华为云高红霞: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

相关文章

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,