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

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

SQLite3命令行工具最佳实践指南

《SQLite3命令行工具最佳实践指南》SQLite3是轻量级嵌入式数据库,无需服务器支持,具备ACID事务与跨平台特性,适用于小型项目和学习,sqlite3.exe作为命令行工具,支持SQL执行、数... 目录1. SQLite3简介和特点2. sqlite3.exe使用概述2.1 sqlite3.exe

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过