骚年快答 | 技术中台与业务中台都是啥?

【答疑解惑作者 / Edison Zhou

这是恰童鞋骚年的第262篇原创内容


最近有童鞋在我之前发布的《聊聊中台》一文中提问:技术中台是什么?和业务中台又有什么区别?考虑到在工作中,也有部分同事问过这个问题,我这里总结一下形成此文进行答复。

1复习:什么是中台

这里引用王健老师在专栏《说透中台》中给中台下的定义:“企业级能力平台”。

所谓企业级,主要是指中台处理的问题范围在企业级别,即包含多条业务线或服务多个前台产品(团队),且建设中台一定要跳出单条业务线、站在企业整体视角来审视业务全景。

所谓能力,主要是指中台主要承载的对象,每家企业的核心能力都不同,要找到差异化竞争力。

所谓复用,即中台的核心价值,它的可复用及易复用的特性能够实现更多地对前台业务的支撑。

所谓平台,即中台的主要形式,它通过对于更细粒度能力的识别与平台化沉淀,实现企业能力的柔性复用。

在之前我的《聊聊中台》一文中,重点强调和介绍了业务中台,这是大部分谈论中台的人谈到的中台类型,因为不论什么中台,最终都是为业务服务,赋能前台,提高企业的用户响应力的。

中台的兴起,主要源于BATJ等大厂的推动,他们在2015年兴起的中台战略开始推动了企业组织结构的调整和变革,建立了所谓的“共享服务中心体系”来应对新业务扩展带来的成本,从而实现基础能力的复用,不再进行重复建设和投资。这种以确定性面对不确定性的做法,一经大厂宣传,各家传统行业的企业就纷纷上船,貌似各家都有建设中台的需求。我对这种跟潮流的做法,表示中立态度,拥抱不一定就正确,但是漠视可能会落伍。冷眼旁观,热心研究,未尝不可。

 一个常见的电商业务中台示例图

2技术中台又讲了什么

虽然我比较认可网易云的观点“所有的中台都是业务中台”,而其他的中台其实都是一种广义上的业务中台,被称之为中台,就需要具备一定的业务属性,最终都要为业务服务。但还有众多的其他中台被搬上了舞台,其中作为开发人员的视角,最关心的可能就是技术中台了。

那么,什么是技术中台?这里我们通过下面这张图,来看看阿里是如何定义技术中台的。

 阿里中台体系示意图

通过上图,我们也可以看到阿里的技术中台主要由两部分组成:

(1)IaaS层:基础设施层,主要指计算、存储、网络等基础设施资源,他们通常由服务器、机房及数据中心组成,主要由Ops运维人员进行管理。对于我们中小企业来说,这部分几乎都是交给了云服务商,比如我司使用的阿里云ECS虚拟机等。

(2)PaaS层:平台服务层,主要指中间件技术、大数据和研发平台等,例如Job任务中心组件、统一日志组件、事件总线组件等等。对于我们中小企业来说,这部分可以选择自建,即通过一系列的开源项目组件如EFK、CAP、Hangfire、Hadoop等来搭建供所有的微服务共用,也可以选择直接使用云服务商提供的PaaS级服务来微服务提供基础能力从而可以让我们专注于业务逻辑,比如阿里云的日志服务、MaxCompute大数据服务等。

这就是阿里的技术中台,它强调基础设施和中间件的抽象整合,为业务中台服务(一般以微服务形式展现)提供通用基础能力的支撑,让业务中台服务能够专注于自己的业务领域逻辑开发,减少对于通用基础能力的耗时。

类似的,还可以看看eBay和拍拍贷的中台架构示意图,技术中台都扮演着同样的角色。(均来自于波波老师的《Spring Boot与K8s云原生应用开发》课程PPT)

eBay中台体系示意图

拍拍贷中台体系示意图

3我司的业务中台与技术中台

分享一个我司目前的总体技术体系图,这是我在2018年底的时候画的:

其中,基础服务层就可以理解为是我司的业务中台,他们是用ASP.NET Core开发的微服务来提供基础的业务能力服务,比如用户中心、商品中心、订单中心等等。而支撑组件层就可以理解为是一个技术中台,他们使用各种开源组件搭建的通用中间件集合,为上层所有的微服务API提供通用能力,从而不用过分关注类似日志、Job、监控等通用能力的开发。

最后,你可能会问,为什么要在基础服务层(即业务中台)和API网关之间还要加一层应用服务层(我一般称之为BFF)?这个问题,就留在下一期骚年快答给你回复吧。

往期精彩推文

你可能需要了解一下的中台

基于K8s建设.NET Core技术中台

点个“在看” 就是对我最大的支持

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308832.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[mybatis]映射文件_参数处理_#和$取值区别

#{}:可以获取map中的值或者pojo对象属性的值${}:可以获取map中的值或者pojo对象属性的值 区别: #{}:是以预编译的形式,将参数设置到sql语句中,相当于原生jdbc的PreparedStatement;防止sql注入${…

平台or职位,你怎么选?

这里是Z哥的个人公众号每周五11:45 按时送达当然了,也会时不时加个餐~我的第「150」篇原创敬上大家好,我是Z哥。这周有位小伙伴和我聊到一个问题,选择工作的时候是平台重要还是职位重要?我想,很…

闲谈设计模式

闲谈设计模式Intro设计模式(Design Pattern)是一套被反复使用、多数人知晓的、经过分类的、代码设计经验的总结。了解这些前辈们总结出来的经验有助于帮助你写出来更优秀的代码,帮助你写出可扩展、可读、可维护的高质量代码。在极客时间里推出…

[mybatis]log4j

引入依赖&#xff1a; <dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency>在资源文件下写一个log4j配置文件: <?xml version"1.0" encoding"UT…

eShopOnContainers 知多少[11]:服务间通信之gRPC

1. 引言最近翻看最新3.0 eShopOncontainers源码&#xff0c;发现其在架构选型中补充了 gRPC 进行服务间通信。那就索性也写一篇&#xff0c;作为系列的补充。2. gRPC老规矩&#xff0c;先来理一下gRPC的基本概念。gRPC是Google开源的RPC框架&#xff0c;比肩dubbo、thrift、brp…

[mybatis]映射文件_参数处理_#取值时指定参数相关规则

jdbcType通常需要在某种特定的条件下被设置&#xff1a; 在我们数据为null的时候&#xff0c;有些数据库可能不能识别mybatis对null的默认处理。比如Oracle&#xff08;报错&#xff09;&#xff1b;jdbcType OTHER&#xff1a;无效的类型&#xff1b;因为mybatis对所有的null映…

龙芯开源社区上线.NET主页

龙芯团队从2019年7 月份开始着手.NET Core的MIPS64支持研发&#xff0c;经过将近一年的研发&#xff0c;在2020年6月18日完成了里程碑性的工作&#xff0c;在github CoreCLR 仓库&#xff1a;https://github.com/gsvm/coreclr&#xff0c; 随后受到.NET社区的很大参与热情鼓舞之…

[mybatis]映射文件_select_返回集合(List,Map)

select返回List public interface EmployeeMapper {public List<Employee> getEmpsByLastNameLike(String lastName);}<!-- public List<Employee> getEmpsByLastNameLike(String lastName);--><!--resultType;如果返回的是一个集合&#xff0c;要写集…

免费 | 数千个 Azure 官方高清矢量图标大放送!

点击上方关注“汪宇杰博客” ^_^导语我们平时绘制云应用架构图时&#xff0c;经常要用 Azure 各项服务的图标。不知各位会自己去截图&#xff0c;还是在浏览器 F12 里使劲抠图&#xff1f;是不是做PPT 5分钟&#xff0c;扣图2小时&#xff1f;现在用不着自己使劲啦&#xff0c;…

使用sqlserver搭建高可用双机热备的Quartz集群部署

一般拿 Timer 和 Quartz 相比较的&#xff0c;简直就是对 Quartz 的侮辱&#xff0c;两者的功能根本就不在一个层级上&#xff0c;如本篇介绍的Quartz强大的集群机制&#xff0c;可以采用基于sqlserver&#xff0c;mysql的集群方案&#xff0c;当然还可以在第三方插件的基础上实…

从Memcached到Redis,从RabbitMQ到Kafka,为了高并发,这些年我们不容易!

周一上班又撕了一页台历&#xff0c;随即心里头却是一惊。如今高考落下帷幕&#xff0c;不曾想2020竟已过了一半&#xff01;这一年又是疫情又是洪水&#xff0c;我们的目光被各种重大事件所吸引&#xff0c;此时审视一下自己&#xff0c;突然觉得不踏实了&#xff01;一场疫情…

[mybatis]动态sql_if_where_trim判断OGNL

OGNL if 要求&#xff1a;查询员工&#xff0c;要求&#xff0c;携带了哪个字段查询条件就带上这个字段的值 //携带了哪个字段查询条件就带上这个字段的值public List<Employee> getEmpsByConditionIf(Employee employee);<!-- public List<Employee> getEm…

[mybatis]动态sql_choose_分支选择

choose 如果带了id就用id查&#xff0c;如果带了lastName就用lastName查&#xff1b;只会进入其中一个 public List<Employee> getEmpByConditionChoose(Employee employee);<!-- public List<Employee> getEmpByConditionChoose(Employee employee);-->…

7.15周三晚8点,dotnet课堂全新起航,张善友/陈计节/刘腾飞我们一起来聊聊abp的故事...

直播主题&#xff1a;我们和Abp的故事直播嘉宾&#xff1a;张善友&#xff0c;陈计节&#xff0c;刘腾飞直播话题张善友&#xff1a;我是如何使用Abp的刘腾飞&#xff1a;利用Abp的模块化解决单体和分布式混合架构陈计节&#xff1a;Abp开源项目的DevOps实践Abp VNext 处于被低…

ASP.NET Core端点路由 作用原理

端点路由(Endpoint Routing)最早出现在ASP.NET Core2.2&#xff0c;在ASP.NET Core3.0提升为一等公民。Endpoint Routing的动机在端点路由出现之前&#xff0c;我们一般在请求处理管道的末尾&#xff0c;定义MVC中间件解析路由。这种方式意味着在处理管道中&#xff0c;MVC中间…

程序员修神之路--分布式系统设计理念这么难学?

点击“蓝字”关注我们吧福利&#xff1a;有件小事想和大家说一下菜菜哥&#xff0c;问你个问题&#xff0c;为什么现在的系统都设计为分布式系统呢&#xff1f;这个问题问得好&#xff0c;就像为什么程序员会慢慢脱发一样神奇01PART分布式系统身为二十一世纪的一名程序员&#…

使用keepalived搭建双机热备高可用一览

很多时候大家为了部署高可用方案都是前端配一个 nginx&#xff0c;如果nginx挂掉怎么办&#xff0c;比如下面这张图&#xff1a;你可以清楚的看到&#xff0c;如果 192.168.2.100 这台机器挂掉了&#xff0c;那么整个集群就下线了&#xff0c;这个问题该怎么解决呢&#xff1f;…

Linus通过了Linux中避免master/slave等术语的提案

Linux 内核维护者 Dan Williams 曾于 7 月初提交一份提案&#xff0c;建议逐步取消 master/slave 和 blacklist/whitelist 术语。近日&#xff0c;Linus Torvalds 则在 Linux 5.8 版本库的拉取请求中批准了该提议。自此&#xff0c;Linux 开发人员则需要使用新的术语来替代 mas…

[mybatis]缓存_一级缓存_一级缓存失效的四种情况

1.sqlSession不同 Testpublic void test05() throws IOException {SqlSessionFactory sqlSessionFactory getSqlSessionFactory();SqlSession sqlSession01 sqlSessionFactory.openSession();try{EmployeeMapper mapper01 sqlSession01.getMapper(EmployeeMapper.class);Emp…

LINQ :最终统治了​所有的语言!

LINQ&#xff1a;最终统治了所有的语言&#xff01;让我们看看LINQ如何彻底改变了.NET中访问数据的方式.NET与其他技术栈的不同之处之一绝对是LINQ&#xff0c;它是Language Integrated Query的首字母缩写。实际上&#xff0c;它是随.NET Framework 3.5和Visual Studio 2008引入…