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

相关文章

JDK21对虚拟线程的几种用法实践指南

《JDK21对虚拟线程的几种用法实践指南》虚拟线程是Java中的一种轻量级线程,由JVM管理,特别适合于I/O密集型任务,:本文主要介绍JDK21对虚拟线程的几种用法,文中通过代码介绍的非常详细,... 目录一、参考官方文档二、什么是虚拟线程三、几种用法1、Thread.ofVirtual().start(

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

springboot依靠security实现digest认证的实践

《springboot依靠security实现digest认证的实践》HTTP摘要认证通过加密参数(如nonce、response)验证身份,避免明文传输,但存在密码存储风险,相比基本认证更安全,却因... 目录概述参数Demopom.XML依赖Digest1Application.JavaMyPasswo

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

Java服务实现开启Debug远程调试

《Java服务实现开启Debug远程调试》文章介绍如何通过JVM参数开启Java服务远程调试,便于在线上排查问题,在IDEA中配置客户端连接,实现无需频繁部署的调试,提升效率... 目录一、背景二、相关图示说明三、具体操作步骤1、服务端配置2、客户端配置总结一、背景日常项目中,通常我们的代码都是部署到远程

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni