10 月 23 - 25 日,QCon 上海站即将召开,现在购票,享9折优惠 了解详情
写点什么

中台战略:业务中台的 8 个设计原则

  • 2020-04-27
  • 本文字数:2166 字

    阅读完需:约 7 分钟

中台战略:业务中台的8个设计原则

业务中台是一个充满生命力的个体,它承载业务逻辑、沉淀业务数据、产生业务价值,并随着业务不断发展进化。它的设计遵循如下图所示的 8 个原则。



业务中台设计的 8 大原则

服务松耦合原则

(1)面向接口实现


这是服务松耦合的基本要求,即每一个服务都按接口的定义进行实现。服务的消费方不需要依赖某个特定的服务实现,避免服务提供方的内部变更影响到消费方。另外,在服务提供方切换到其他系统时,不影响服务消费方的正常运行。


(2)异步事件解耦


服务间的事件通信采用异步消息队列来实现。由于有消息队列这个中介,因此生产者和消费者不必在同一时间都保持实时处理能力,而且消费生产者也不需要马上等到回复。


(3)服务提供者位置解耦


服务消费者不需要直接了解服务提供者的具体位置信息,例如 IP 地址、端口。典型解决方法是服务注册中心,服务提供者启动时将自己注册到服务注册中心,服务消费者通过服务注册中心查找具体服务提供者来访问。同时,服务注册中心可以提供负载均衡及 fail-over 的能力。


(4)版本松耦合


消费端不需要依赖服务契约的某个特定版本来工作,这就要求服务契约在升级时尽可能提供向下兼容性。


02 服务依赖原则


(1)有价值的领域模型


  • 价值导向:确保业务中心的服务都与企业的商业理想保持一致,相关联。

  • 简捷为美:业务逻辑和流程避免复杂化。

  • 领域洞察:紧贴业务的核心目的,从业务原则指导业务逻辑的设计。


(2)服务间最小依赖


  • 高内聚:同一类服务应归在一起。

  • 低耦合:服务间保持最小联系。

  • 能力与接口:业务流程和业务逻辑的操作都作为中心服务实现,而提供给外部调用的接口数据模型都会转化为服务。

  • 识别通用性:识别出每个通用能力的可扩展的类型,从设计上支持它不断扩展,并在接口定义上满足其不断升级的需求。


(3)能力实体具有层次性


  • 能力与接口:分离接口实体与能力实体。

  • 接口实体与限定元素:将接口实体核心元素与接口操作的限定元素分离。

  • 接口实体的层次结构:建设接口实体和上下文限定元素的层次结构。


(4)延迟对技术组件的依赖


捆绑依赖:


避免在无关的组件技术之间引入新的依赖。


延迟绑定:


在使用点才捆绑依赖关系。

服务设计原则

(1)优化远程调用


服务间的远程调用分为同步调用和异步调用两种模式。应当分析服务调用场景,选择较优的调用模式。


(2)去掉冗余数据


尽量去掉接口实体中客户端不需要的冗余字段,既能减少网络开销,又能避免给前端解析带去复杂性。


(3)设计粗粒度的服务接口


服务接口若能与前端一个用例或一个业务场景相对应(粒度较粗)则既能减少远程调用次数,又能降低学习成本。


(4)识别并设计通用的服务接口


由于中心服务不限定应用范围,因此一般要支持不同的应用。但不同应用在功能丰富性上有很大差异,这就决定了服务接口需要尽可能保证广泛兼容性。譬如,服务接口的参数和返回值必须是被广泛支持的较简单的数据类型。


(5)隔离服务内部的变化


避免服务内部的领域模型直接传导给客户端。如未能提供合理的隔离措施,则当服务进行内部重构时,势必导致客户端频繁变化。


(6)服务接口先行


详细规定服务与客户端双方对接的内容与形式等,对双方形成强有力的约束和保障。


(7)服务接口向下兼容


由于应用的广泛性,在服务公开发布之后就要保证相当的稳定性,不能随便重构,即使升级也要尽可能考虑向下兼容性。

服务命名原则

强烈建议使用服务使用者专业领域内有意义的名称,优先选用业务概念而不是技术概念。


使用名词命名服务,使用动词命名操作。

服务颗粒度原则

服务应是内聚而完整的,能够独立完成一个职责。在服务内部可以是由多个逻辑上密切相关的代码块共同组成。

服务的无状态性原则

微服务体系的基本要求是服务无状态。无状态的服务是可伸缩、高可用性的基础。

服务操作设计原则

操作表示业务动作,应当使用具体的业务含义而不是泛型操作来定义操作。相关的最佳实践如下:


  • 重要的服务不能依赖非重要服务。

  • 任何服务调用都要设定超时时间。

  • 任何服务的调用结果只有三种可能:成功、失败或未知。

  • 能异步调用的服务尽量使用异步调用,从而提高系统响应速度,降低系统之间的耦合性。

  • 系统拆分时,粒度大小以一个系统 3~8 个开发人员维护为宜。

  • 系统拆分时,往往先拆分数据服务层,因为数据服务层通常是复用性高的一层。

  • 服务的实现不能有单点。

  • 线上遵循 fast-fail 原则,避免服务调用时间过长,导致性能下降。fast-fail 原则是只要发生错误,则调用立即返回。

  • 需要对高压场景下的服务调用链路进行特殊处理,可采用将链路缩短、预热等方式。

  • 服务设计过程中,要避免同类服务由不同服务单元提供。

  • 服务要做到向后兼容,如果无法做到,则需要采取管控机制确保服务消费者升级服务。

  • 服务化架构的变化要使组织的架构能适应这种变化。

  • 在部署服务单元时,要将读服务和写服务分离,将核心服务和非核心服务分离,以保证整个服务单元的稳定性和可靠性。

  • 服务化时,要同时考虑安全。

  • 静态资源也可以实现服务化,实现静态资源与动态资源分离,从而提高性能。

  • 通过在外层系统埋点,可以实现面向终端用户服务的精细管理,比如服务的容量、服务的性能等。

  • 需要将每个业务领域的通用规则沉淀成服务。

服务约束原则

  • 上可依赖下;

  • 下不可依赖上;

  • 上可跨级依赖下;

  • 平级可允许单向调用,坚决禁止循环依赖;

  • 高级别不可依赖低级别;

  • 简单就是美;


重要的服务不能依赖非重要服务。


本文转载自技术琐话公众号。


原文链接:hhttps://mp.weixin.qq.com/s/yArlYBvIuZaEKJwm_Y5Z_g


2020-04-27 17:332176

评论

发布
暂无评论
发现更多内容

一键视频图片解析下载工具SnapAny for Mac免费版

Rose

VMware NSX 4.2.2.1 发布,新增功能简介

sysin

nsx

25年河北等保测评机构名称以及地址一览表

行云管家

等保 等保测评

粒子枪仿真和Track Solver追踪求解_CST案例分析

思茂信息

cst cst操作 CST Studio Suite

Apache Doris 2.1.10 版本正式发布

SelectDB

大数据 开源 实时数仓 Apaache Doris 数据湖分析

多源多表写入、数据格式增强,SeaTunnel 2.3.11 重磅更新来了!

白鲸开源

大数据 开源 数据同步 Apache SeaTunnel 版本发布

上新功能!通义灵码行间建议预测 NES 使用方法

阿里巴巴云原生

阿里云 通义灵码

专业的Mac菜单栏管理工具 Bartender 5

Rose

Topaz Video AI v7.0.1 一键激活版 AI视频无损缩放增强

Rose

Swinsian for Mac(音乐播放器)v3.0Preview23永久激活版

Rose

.NET 9中的异常处理性能提升分析:为什么过去慢,未来快

电子尖叫食人鱼

.NET 7

Capture One Studo 16.6.1.21 专业的 RAW 格式转换器-Mac/win

Rose

当企业遇上JNPF低代码,会擦出什么火花?

引迈信息

Fluss 实战:用 Partial Update 构建实时宽表的新范式

Apache Flink

大数据 flink Fluss

会员付费漫画小程序:微擎开源生态下的内容变现新范式

微擎应用市场

零风险操作!DolphinScheduler高可用架构下的无损扩缩容指南

白鲸开源

开源 运维 Apache DolphinScheduler 扩缩容 任务调度平台

上新功能!通义灵码行间建议预测 NES 使用方法

阿里云云效

阿里云 通义灵码

ssh配置文件管理工具 SSH Config Editor Pro for Mac

Rose

社区答疑明星招募令 | 成为SeaTunnel社群“技术担当”,我们等你来!

白鲸开源

开源社区 数据集成 Apache SeaTunnel 开源活动

为什么数字化转型失败率这么高?

积木链小链

数字化转型 数字化 智能制造

文件压缩与归档利器BetterZip for Mac v5.4中文版

Rose

阿里云事件总线 EventBridge 正式商业化,构建智能化时代的企业级云上事件枢纽

阿里巴巴云原生

阿里云 云原生 EventBridge

智慧文旅行业是否需要购买堡垒机?为什么?

行云管家

网络安全 数据安全 堡垒机 智慧文旅

Muu 线下活动:微擎开源生态下的全流程活动管理与营销平台

微擎应用市场

壹佰门店社区团购:微擎开源生态下的社区零售增长引擎

微擎应用市场

【每天学点‘音视频’】面试官:什么是音视频及实时音视频

小曾同学.com

音视频 H264 RTC 实时音视频

南开大学赵宏教授解读AI语境下的教育根本问题,相关白皮书已发布

ModelWhale

AI教育 南开大学 人工智能教育 学科+AI白皮书

智慧酒店多商户合伙人:微擎开源生态下的酒店行业资源整合平台

微擎应用市场

StoreView SQL,让数据分析不受地域限制

阿里巴巴云原生

阿里云 云原生 sls

YMatrix 的 HTAP 能力和其他数据库有何不同?

YMatrix 超融合数据库

HTAP 超融合数据库 HTAP 场景实践 YMatrix HTAP数据库

(Folx下载器)Folx Pro 5.28 Mac下载管理器

Rose

中台战略:业务中台的8个设计原则_文化 & 方法_技术琐话_InfoQ精选文章