业务层,到底需不需要服务化?

2023-11-30 13:58

本文主要是介绍业务层,到底需不需要服务化?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

很多公司,都实施了微服务架构,底层抽象出很多基础数据服务。

基础数据的访问服务化之后,架构如上:

(1)站点业务通过RPC接口,调用基础数据服务;

(2)基础数据服务通过DAO,从db/cache获取数据;

(3)db/cache存储数据;

 

除了基础数据的访问需要服务化,业务层是否需要服务化?如果需要,什么时机进行服务化?这是本文要讨论的两个问题。

随着时间的推移,系统架构并不会一成不变:

(1)随着业务越来越复杂,业务会不断进行垂直拆分;

画外音:以58同城为例,有招聘、房产、二手、二手车、黄页等多个业务。

(2)随着数据越来越复杂,基础数据服务也会越来越多;

画外音,例如:用户服务,订单服务,搜索服务,推荐服务等。

 

于是系统架构变成了上图这个样子,业务垂直拆分,有若干个基础数据服务:

(1)垂直业务要通过多个RPC接口访问不同的基础数据服务,服务共享是服务化的特征;

(2)每个基础数据服务访问自己的数据存储,数据私有也是服务化的特征;

 

上面架构图中的依赖关系是不是看上去很别扭?

(1)基础数据服务与存储层之间连接关系很清晰;

(2)业务站点层与基础数据服务层之间的连接关系错综复杂,变成了蜘蛛网;

 

再举一个更具体的例子,58同城列表页站点如何获取底层的数据?

(1)首先调用商业基础服务,获取商业广告帖子数据,用于顶部置顶/精准的广告帖子展示;

(2)再调用搜索基础服务,获取自然搜索帖子数据,用于中间自然搜索帖子展示;

(3)再调用推荐基础服务,获取推荐帖子数据,用于底部推荐帖子展示;

(4)再调用用户基础服务,获取用户数据,用于右侧用户信息展示;

(5)…

 

如果只有一个列表页这么写还行,但如果有招聘、房产、二手、二手车、黄页等多个业务,都这么获取共性数据,而只有少部分个性数据,每次都这么一个个调用基础服务,有大量冗余、重复、每次必写的代码。

 

特别的,不同业务上游列表页都依赖于底层若干相同服务:

(1)一旦一个服务RPC接口有稍许变化,所有上游的系统都需要升级修改;

(2)子系统之间很可能出现代码拷贝;

(3)一旦拷贝代码,出现一个bug,多个子系统都需要升级修改;

 

如何让数据的获取更加高效快捷呢?

业务服务化,通用业务服务层的抽象势在必行。

 

通过抽象通用业务服务层,例如58同城“通用列表服务”:

(1)业务站点层,可以通过RPC接口,像调用本地函数一样,调用通用业务服务,一次性获取所有通用数据;

(2)通用业务服务,也可以通过多次调用基础数据服务提供的RPC接口,分别获取数据,底层数据获取的复杂性,全都屏蔽在了此处;

是不是连接关系也看起来更清晰?

这样的好处是:

(1)复杂的从基础服务获取数据代码,只有在通用业务服务处写了一次,没有代码拷贝;

(2)底层基础数据服务接口发生变化,只有通用业务服务一处需要升级修改;

(3)如果有bug,不管是底层基础数据服务的bug,还是通用业务服务的bug,都只有一处需要升级修改;

(4)业务站点层获取数据更便捷,获取所有数据,只需一个RPC接口调用;

 

于是,当业务越来越复杂,垂直拆分的系统越来越多,基础数据服务越来越多,底层数据获取复杂性成为通用痛点的时候,就应该抽象出通用业务服务,简化数据获取过程,提高数据获取效率,向上游屏蔽底层的复杂性。

 

最后再强调两点:

(1)是否需要抽象通用业务服务,和业务复杂性,以及业务发展阶段有关,不可一概而论;

画外音:如果没有多个业务线,大概率基础服务就够用。

(2)需要抽象什么通用业务服务,和具体业务相关;

画外音:帖子列表业务服务,帖子详情业务服务,是58同城特有的;而基础服务,例如用户,订单,支付等基础服务,基本上各个公司是类似的。

 

任何脱离业务的架构设计,都是耍流氓。

调研:

(1)贵司有没有基础服务?

(2)贵司有没有业务服务?

这篇关于业务层,到底需不需要服务化?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

业务协同平台--简介

一、使用场景         1.多个系统统一在业务协同平台定义协同策略,由业务协同平台代替人工完成一系列的单据录入         2.同时业务协同平台将执行任务推送给pda、pad等执行终端,通知各人员、设备进行作业执行         3.作业过程中,可设置完成时间预警、作业节点通知,时刻了解作业进程         4.做完再给你做过程分析,给出优化建议         就问你这一套下

深入解析秒杀业务中的核心问题 —— 从并发控制到事务管理

深入解析秒杀业务中的核心问题 —— 从并发控制到事务管理 秒杀系统是应对高并发、高压力下的典型业务场景,涉及到并发控制、库存管理、事务管理等多个关键技术点。本文将深入剖析秒杀商品业务中常见的几个核心问题,包括 AOP 事务管理、同步锁机制、乐观锁、CAS 操作,以及用户限购策略。通过这些技术的结合,确保秒杀系统在高并发场景下的稳定性和一致性。 1. AOP 代理对象与事务管理 在秒杀商品

【H2O2|全栈】Markdown | Md 笔记到底如何使用?【前端 · HTML前置知识】

Markdown的一些杂谈 目录 Markdown的一些杂谈 前言 准备工作 认识.Md文件 为什么使用Md? 怎么使用Md? ​编辑 怎么看别人给我的Md文件? Md文件命令 切换模式 粗体、倾斜、下划线、删除线和荧光标记 分级标题 水平线 引用 无序和有序列表 ​编辑 任务清单 插入链接和图片 内嵌代码和代码块 表格 公式 其他 源代码 预

设置zookeeper开机自启动/服务化

设置启动zk的用户为zookeeper 设置启动zk的用户为zookeeper用户,而非root用户,这样比较安全。 可以使用root用户进行zookeeper的管理(启动、停止…),但对于追求卓越和安全的的人来说,采用新非root用户管理zookeeper更好。 步骤: 1. 创建用户和用户组 2. 相关目录设置用户和用户组属性 3. 采用zookeeper用户启动进程 设置z

业务资源管理模式语言09

示例: 图13 表示了QuoteTheMaintenance 模式的一个实例,在汽车修理店系统中,其中“Vehicle”扮演“Resource”,“Repair Quotation”扮演“Maintenance Quotation”,“Repair shop branch”扮演“Source-party”,“Customer”扮演“Destiny-Party”。 图13——QuoteThe

Linux block_device gendisk和hd_struct到底是个啥关系

本文的源码版本是Linux 5.15版本,有图有真相: 1.先从块设备驱动说起 安卓平台有一个非常典型和重要的块设备驱动:zram,我们来看一下zram这个块设备驱动加载初始化和swapon的逻辑,完整梳理完这个逻辑将对Linux块设备驱动模型有深入的理解。 zram驱动加载的时候会调用zram_add函数,源码如下: 1887/*1888 * Allocate and initia

首次揭秘,面向核心业务的全闪分布式存储架构设计与实践

当今是云计算、大数据的时代,企业业务持续增长需要存储系统的 IO 性能也持续增长。 机械盘本身的 IOPS 一直徘徊在数百的级别,为了提高传统存储的性能,有些存储厂商加了缓存层,然而目前应用正由单一走向多元化,导致 IO 特征无法预测,缓存也难以发挥作用。 机械盘依赖盘片的旋转和机械臂的移动进行 IO,目前转速基本达到物理极限,所以机械盘性能一直徘徊不前,无法满足企业核心业务对于存储性能的要求

DDoS安全防护:为您的业务保驾护航

随着互联网技术的发展,网络安全问题日益凸显,尤其是分布式拒绝服务(DDoS)攻击,已成为众多企业和个人无法忽视的风险之一。DDoS攻击是指攻击者利用多台受感染的计算机作为“僵尸”向目标发起大量合法请求,以耗尽目标资源或带宽,导致合法用户无法访问服务。 DDoS安全防护的特性 DDoS安全防护不仅能够实时监控并检测潜在的攻击威胁,还能迅速采取措施进行流量清洗,确保业务的连续性和稳定性。具体来说,

MVVM到底是什么

MVVM到底是什么 文章目录 MVVM到底是什么一、MVVM是什么二、为什么这么定义1. 分离关注点2. 提高可维护性3. 数据绑定和事件驱动4. 支持前端框架的发展 三、底层逻辑1. ViewModel层2. 数据绑定3. 事件驱动4. 响应式系统 四、扩展与高级技巧1. 组件化开发2. 双向数据绑定3. 计算属性和侦听器4. 插槽