全图化在线系统设计

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

相关文章

Windows系统宽带限制如何解除?

《Windows系统宽带限制如何解除?》有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文就跟大家一起来看看Windows系统解除网络限制的操作方法吧... 有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用