当前位置: 首页 > 产品展示 > 数码模块

火博sports

PRODUCTS
×

火博sports从4万行代码降到18万腾讯竟然用DDD做架构重

发布时间:2024-02-26 19:06:46 来源:火博体育首页 作者:HB火博APP官网

  DDD 的指导思想很多时候较为晦涩,与实际业务中的架构设计场景往往较难结合理解。本文通过引入架构映射等方式将二者结合,试图给出一套量化评估方法并通过腾讯视频一起看系统的实践案例说明如何应用。

  本文将通过腾讯视频一起看系统的架构重构实践,给出一套可供参考的领域建模、架构设计与量化评估准则。

  视频会员部门目前正在进行领域驱动项目,希望借助 DDD 的一些方,对会员的整个技术体系做一个梳理。内容作为其中的一个子领域,也希望借助 DDD 的一些方法进行整个体系的建设:

  ▶︎ 复杂度:既有业务复杂度(涉及播放、购买、活动、内容展示、内容互动等全场景),也有技术复杂度(涉及业务规则、模块众多、请求量大、信息安全等),需要拉通考虑

  ▶︎ 跨部门合作:目前的会员内容体系,至少涉及会员、直播中台、腾讯云、安平审核等部门,是一个跨部门协作项目。

  在理解产品需求的基础上,从中提取出核心概念,然后建立起核心概念的逻辑结构,概念的逻辑结构即领域模型,通常可以用领域图或 ER 图来表示。领域模型有助于我们以一种抽象的视角来理解复杂业务。

  对于复杂大系统,DDD 给出的基本操作方法就是大分形,即大而化之、分而治之、形而上之。将这个方法应用在内容体系上,可以做一个初步的领域建模。

  将上面的方法应用在视频会员内容体系上,可以做一个初步的领域建模。针对会员内容体系业务梳理,以内容为核心,共分为4块:

  除了上面定义的那些运营性与结构性架构特征外,我们过往的系统开发实践中,似乎一直忽略了很重要的架构特征,即“模块化”,这一架构特征可以看做是隐式的架构特征。

  关于软件架构的用语中有95%以上都在称颂“模块化”,而关于如何实现“模块化”的用语却少之又少。-Glenford J.Myers(1978年)

  不同的平台提供了不同的代码重用机制,但是所有平台都支持以某种方式将相关代码分组到模块中。虽然模块的概念在软件架构中是通用的,但一直没有统一的定义。从 Myers 的引言中可以看出,这不是一个新问题。

  在开发平台中了解模块化及其多种形式,对于架构师来说至关重要。分析架构的许多工具(例如度量指标、适应度函数和可视化)都依赖于这些模块化概念。模块化是一种组织原则。如果架构师在设计系统时没有注意各个部分是如何连接在一起的,那么最终创建的系统必将存在众多问题。从物理学的角度来看,软件系统是对趋于熵(或无序)的复杂系统进行建模,必须将能量添加到物理系统中以保持秩序。软件系统也是如此:架构师必须不断消耗精力以确保良好的结构稳定性。

  保持良好的模块化体现了我们对一种隐式的架构特征的定义:几乎没有项目要求架构师去确保良好的模块化划分并以模块化为主题与项目成员沟通,而可持续的代码则需要秩序和一致性。

  我们使用模块化来描述代码的逻辑分组,该逻辑分组可以是面向对象语言中的一组类也可以是结构化语言和函数式语言中的函数。大多数语言都提供了模块化的机制(Java 中的包(package),NET 中的命名空间(namespace),等等。开发人员通常使用模块作为将相关代码分组在一起的一种方式。

  模块化对架构师非常重要,研究人员创建了各种跨语言的度量标准来帮助架构师理解块化。我们重点聚焦三个关键概念:内聚性、耦合和共生性。

  作为开发,我们工作的本质就是把一个产品需求转化成一个可以运行的系统,中间涉及产品设计、领域建模、架构设计、详细设计、代码编写、测试等步骤。

  只有对于一些特别复杂的业务,在理解产品需求的基础上,从中提取出核心概念构成领域模型,然后把领域模型中的概念分解到系统架构中的各层和各模块中去。架构映射即是把领域模型映射到系统架构。

  领域驱动设计的重点在系统设计阶段,但领域驱动设计同样将重构作为重要内容。某种程度而言,软件工程师仍然是手工业者,软件开发仍然没有银弹,重构仍然是软件在生长过程中不可或缺的调校手段。

  因此,我们也不用迷信什么银弹,也不必忌讳什么过度设计与设计不足,通过多次重构迭代,让正确的设计逐步显现。

  视频一起看,经过几年不断的功能开发,已经堆砌了比较多的模块,而且是由两个跨部门的团队一起开发的,整体上缺乏统一设计,技术债务积累较多,亟需来一次整体重构。

  严格遵守分层架构,上层服务可以调用下层服务,下层服务禁止调用上层服务,下层服务不关心业务逻辑。如果上下层服务需要发生交互,通过逻辑解耦的方式进行,如消息队列/中转。

  通过重新调整领域划分,使得功能分布上更为合理,各个模块专注于专属领域相关能力,更利于后续开发和维护。

  以 room_adapter 为例,因为属于业务适配层,掺杂了太多的特殊业务逻辑,导致代码可读性,可维护性很差;

  梳理服务流程,将非核心的业务逻辑抽离为业务子域,封装为 trpc ,保障业务主流程的可维护性。

  在进一步分析系统重构完之后的效果时,我们先补充一点架构方面的知识点,这可以更方便地以一种量化的方式来评估重构效果。

  这部分通过介绍视频会员今年做的一个系统重构项目,结合上面的知识点,对这个项目做一整体量化分析。

  一起看房间系统,这是一个重构项目,如果说明这个项目的意义,通常的结构就是“问题-目标-方案-效果”。

  对于非技术同学(产品、运营)来说,定性说明可能更容易理解,但定性说明本身比较随意,任何一个重构都可以讲出以上这些好处,所以没有区分度。

  这样我们就可以对比重构前系统与重构后系统的区别,可以看到重构后的系统在可测试性、扩展性及模块化方面都有明显改进。

  ▶︎ 重构前:room adapter 模块包含了太多低耦合逻辑,除房间业务逻辑外,还有定时任务、房间回调、进房审批鉴权、消息发送。

  ▶︎ 重构后:room_adapter 模块只保留房间业务逻辑,其他逻辑按高内聚低耦合拆分为独立小模块。

  成本方面,通过下图趋势线 成本均呈下降趋势,其中 PCG-123 和日志服务 CLS 成本降幅明显,达到40%左右

  ▶︎ 我们在描述架构时,通常会采用高性能、扩展性、可观察性等几个点,缺乏一个整合的量化分析框架,本文试图解决这一问题,让不同的架构风格具有可对比性;

  ▶︎ 领域建模和架构设计之间的关系是什么,本文提出“架构映射”的概念,试图建立起两者之间的转换关系;

  ▶︎ 做过很多重构,重构前后系统效果的说明,通常会采用定性描述,或者列举单点说明,比如性能、扩展性等,如何以一种可量化的整合的方式说明重构的效果。


火博sports