全图化在线系统设计

2023-10-10 05:20
文章标签 设计 系统 在线 全图化

本文主要是介绍全图化在线系统设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Pillars是什么

Pillars是一个Serverless全图化业务托管平台。Pillars应用全图化开发模型,提供丰富的运行时组件,支持CI/CD全生命周期项目管理,具备主动式资源优化能力。

Pillars解决什么问题

当前广告系统架构采用分布式微服务的设计理念,通过服务分治实现各组织间开发、运维、资源等维度解耦,并通过RPC实现服务间通信,实现多服务联动。微服务的逻辑基础是“服务自治”与“服务复用”,这些设计从软件管理、资源适配两个维度给业务系统带来了诸多好处。但随着广告业务复杂度增长,广告中台系统呈现出“服务间联动”与“流量端自治”两个趋势。这些变化趋势逐渐打破微服务理念的逻辑基础,在研发效率、持续集成、资源利用率等方面给系统带来一系列问题。
Pillars希望通过建设全图化业务托管系统,将按照服务分治的水平物理架构转变为按照业务场景分治的垂直逻辑架构,提供全业务视图的研发、运维体系,同时进一步提升在线执行引擎调度、混部的灵活性,实现算子粒度的资源智能编排,以追求资源最大化利用。

当前痛点

开发视角

  • 瞻前顾后:在开发某个逻辑的时候,需要首先熟悉前后相关逻辑,确定依赖的前置逻辑能正确执行,确保修改逻辑对后面逻辑不会产生预期外的影响。
  • 扑朔迷离:业务代码和实验参数高度耦合,难以清晰看到全局业务流程,难以高效清除废弃逻辑。

集成交付视角

  • 左顾右盼:部分业务改造和系统级项目(nuwa、addebug)涉及多个模块配合上线,需要考虑上下游兼容发布等问题,费时费力。
  • 闭关锁国:模块一旦完成划分,重新调整边界成本高(如cypher-inspire合并、inspire-sendcontrol拆分),导致系统的重构难度加大,不便于长期管理。

系统资源视角

  • 指鹿为马:模块划分规则并未遵从系统最优原则,而是以经验主导进行面向组织分工的划分,存在系统层面的损耗。
  • 舍近求远:星型架构下,各叶子节点服务间传输数据须经中心节点转发,造成带宽、CPU浪费,且会增加延时。

痛点的深层原因

  • 系统熵增:业务永远在迭代,业务系统会越来越复杂。
  • 组织分工:分工虽然提升了内部效率,但也引入了边界损耗,业务团队间、业务与中台间、中台各个模块间存在大量认知成本、协作成本。
  • 自动化、智能化缺失:目前仍需人力介入大量重复性工作,并依赖人力处理大量经验性工作,效率低,质量低,成本高。

解决痛点

开发视角

  • 瞻前顾后 -> 以Lambda算子为开发标准,参考TensorFlow算子实现,利用开发框架强约束开发模式,实现算子内逻辑内聚、算子间逻辑解耦。所有数据依赖通过算子的input、output显式声明,避免跨算子认知负担。
  • 扑朔迷离 -> 用数据流图串联所有算子,提供完善的图DSL,并支持图可视化,清晰表达算子间关系。用条件语句表达图分支,便于在图上进行实验管理,实现执行流程与算子实现解耦,降低理解成本。

集成交付视角

  • 左顾右盼 -> 建设以业务图为粒度的发布体系,用标准化、自动化的发布流程实现跨集群协同发布,并实现完备的版本管理系统,让业务同学在发布时无需关注系统繁琐细节。
  • 闭关锁国 -> 统一算子开发框架与通信框架,建立公共算子仓库组,算子可以在各个机器间灵活移动部署,便于实现面向各种目标的模块间重组。

系统资源视角

  • 指鹿为马 -> 对给定的业务图进行自动化、智能化切分与编排,并对切分后图片段进行全自动部署、切流、实验,提高时延约束下的资源最大化利用。
  • 舍近求远:数据机器间的数据交互模型由RPC常用的“ping-pong模型”变为单向传递的“数据流模型”。

在新的模式下:开发走向Lambda算子化,开发具体逻辑所需的关注域逐渐缩小。psm、模块、服务等概念逐渐弱化,甚至消失,取而代之的是“图”。“图”内的编排、部署、版本管理等全部实现自动化、智能化,数据机器间的数据交互模型由RPC常用的“ping-pong模型”变为单向传递的“数据流模型”。机器资源逐步走向池化,抽象出CPU线程资源池、GPU资源池、内存池、存储池等。此外,系统还需要一系列辅助设施,如CodeGen工具、可观测工具、Debug工具等。

在这里插入图片描述
在这里插入图片描述

pillars的底层逻辑

  • 降低熵增速度:pillars无法实现熵减,但可以促进清理无效复杂度,通过合理标准化降低复杂度增长的速度
  • 降低熵增代价:pillars将沟通成本、认知成本、操作成本等较高的人力成本,转移给成本较低的自动化、智能化机器

潜在收益

痛点是当下已经损失的“沉没成本”,解决痛点是在“及时止损”。在解决痛点的基础上,pillars也借机完善当下尚未做到最好的领域,“追求收益”。

  • 用数据流视角重构广告业务,降低业务理解成本
  • 形成业务图/算子库、中间件算子库,提高复用度,更快速的验证、搭建新业务
  • 消除“多模块视角”的时延约束、资源约束,统一为整体约束,为基于流量价值的资源资源调控打下基础

“能被看到的问题”不是全部问题

痛点是“能被看到的问题”,但是有些问题其实被隐藏在“惯性思维”中,人们并没有觉得不合理。当基础模式发生重大变化时,需要主动做推演,挖掘潜在问题,引导形成更合理的局面。
例如,当psm逐渐

这篇关于全图化在线系统设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

kkFileView在线预览office的常见问题以及解决方案

《kkFileView在线预览office的常见问题以及解决方案》kkFileView在线预览Office常见问题包括base64编码配置、Office组件安装、乱码处理及水印添加,解决方案涉及版本适... 目录kkFileView在线预览office的常见问题1.base642.提示找不到OFFICE组件

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻