写点什么

SOA 为什么不“香”了?丨建设数据中台系列(三)

  • 2020-08-06
  • 本文字数:2653 字

    阅读完需:约 9 分钟

SOA为什么不“香”了?丨建设数据中台系列(三)

SOA 所有的理念都是基于现有应用系统展开的,不管是对服务的梳理还是服务之间的交互,都是以现有应用系统为载体的,中台不同于 SOA 的地方在于:中台是一种平台化思维,它并不是从系统集成的角度去思考问题,而是从架构层面上重构了整个 IT 生态。相比之下,中台无疑是一种更深刻、更底层的变革,因为它完全破除了应用之间的壁垒,把企业的核心业务能力“中心化”,把它们提炼并沉淀到中台的各个业务中心上,而不是面向单一业务方向或渠道的应用系统上。这在 SOA 架构下是很难实现的,因为中台的业务中心与 SOA 的服务载体(即应用系统)之间有着本质区别,它们的定位和服务对象都不同,这些区别决定了 SOA 依然是一种相对松散的分治式的架构,很难与中台这种更加中心化、更为强力的架构体系相抗衡。


烟囱式的生态系统并不是今天才突显出来的,很多企业已经被这个问题困扰多年了,并且尝试过各种措施试图进行改善。回顾企业的 IT 生态变迁史,一段不得不提的历程就是 SOA(面向服务的架构)。本文核心观点援引自作者所著的《大数据平台架构与原型实现:数据中台建设实战》一书,全书对数据中台的理念、架构和具体实现做了详细论述。


大概在 2005 年前后的七八年间,随着 SOA 理念和相关技术(如 ESB)的不断发展和完善,SOA 在当时被认为是改善僵化的 IT 生态、解决烟囱架构等弊病的终极方案而被业界寄予厚望,很多企业在那个时期纷纷上马 SOA 项目,希望凭借 SOA 将企业的 IT 生态拉回到一种理想的状态。十多年后回首当初那场 SOA 热潮,我们发现最终在 SOA 改造上取得成功的企业少之又少,即使曾经取得了一定的成效,伴随后来新业务系统的冲击,当年辛苦建立的 SOA 生态也大都名存实亡,是什么原因导致了这样的结果呢?


人们很早就意识到点对点式的系统间交互是非常糟糕的,在 SOA 起源之前,已经出现了基于消息队列的“消息总线”架构,各个应用系统与消息总线连通,由消息总线负责将消息路由到接收方,从而让应用系统通过中心化的消息总线完成交互,这样就可以消除点对点式的系统交互。但是消息总线用于系统集成时在某些方面依然有所欠缺,例如消息都是静态的、预定义的、无法自描述的,消息接口无法被注册和发现。同时,另外一种以“服务”为视角看待和思考系统间交互的架构思想一直在不断地发展,后来,随着 Web 服务(Web Service)技术的兴起,IT 系统的对外接口逐渐向平台中立的第一代 Web 服务标准(WSDL+SOAP)靠拢,这为实施这一架构打开了大门,这就是 SOA。


从系统集成的角度看,SOA 是一种非常理想的方案,SOA 体系的两大核心如下:


  • 对系统提供的对外交互进行提炼、组织和梳理,通过封装、组合与编排,将接口以“服务”的形式发布出去;

  • 系统间的交互统一通过中心化的企业服务总线(ESB)完成。


典型的 SOA 架构如图 1 所示。



图 1 典型的 SOA 架构


SOA 成功的基础是对“服务”的提炼、组织和梳理,只有服务足够灵活才能支撑各种外部系统的复杂需求,而这一工作需要建立在对业务的深入了解之上,同时要融合良好的设计思想才能达到要求。


SOA 中的“服务”在技术上以 Web Service 为载体,但是在粒度(或者说抽象程度)上会有所不同,主要有如下三种粒度的服务:


  • 基础服务:最细粒度的服务,最基本、最原子的服务都会在这一层,从服务数量上看,这一层也是最多的;

  • 复合服务:是基于多个基础服务组合叠加而成的粗粒度服务,多用于封装并简化由多个基础服务组合实现的共性服务;

  • 业务流程:是通过工作流引擎将多个服务编排起来,形成一个完整的业务流程,这是一种粒度更粗的服务,常用于实现一个标准的、可复用的大尺度业务流程,如审批等。


在应用系统之间,SOA 依靠 ESB 实现系统集成,ESB 是治理点对点式的系统集成的核心手段,它肩负着如下重担:


  • 实现系统间的连通;

  • 数据转换;

  • 智能路由;

  • 安全控制;

  • 可靠性控制;

  • 服务管理;

  • 监控与日志。


以上是对 SOA 的一个基本介绍,SOA 针对烟囱架构的治理主要依赖于两个方面:


  • 一方面立足于每个应用系统,要求系统对提供的“服务”进行提炼和抽象,确保其灵活、可重用,这是让服务满足外部复杂需求的根本保障;

  • 另一方面是通过中心化的交互媒介——ESB 来约束系统间的交互,消除点对点式集成的负面影响。


但令人感慨的是:走到今天,SOA 已经很少被人提及了,回看企业曾经在 SOA 上做出的尝试和努力,最后的效果多数都不够理想。在完成 SOA 改造之后的若干年间,受到后续各种新系统的冲击,很多企业都没能坚守住自己的 SOA 体系,最终又回到了烟囱架构下的野蛮生长状态,这其中的原因主要是:


  • 沟通与协作成本高:新系统迫于业务需求和市场压力,急需上线,对负责的团队而言,与周边系统的对接和调试属于外部不可控因素,团队总是倾向于在内部可控的范围内解决问题,因此会刻意避开对外部服务的依赖,选择自建相关功能,这样一来,系统间的交互会向着衰减的方向发展,重复建设也因此随之蔓延;

  • 组织架构制约:团队往往缺乏为响应其他系统的诉求而改造和升级自身服务的意愿,因为新系统与他们没有直接的利益关系,企业也缺乏适当的奖惩机制促使各团队之间的积极协作,本质上,这是组织架构决定的;

  • 缺乏长效机制:SOA 改造常常是作为一个项目实施的,项目结束之后就不再有专门的组织和团队对 SOA 架构进行持续把控了,后续新的系统在融入 SOA 生态时受到的支持就减弱了,而新系统本身提供的服务也缺乏必要的梳理和管控,有的新系统甚至不对外提供服务。


这些问题并不是 SOA 自身的问题,而是一些普遍的现实问题,也是治理烟囱架构过程中遇到的深层次问题,这些问题阻碍了 SOA 在企业的落地和持续发展。所以说 SOA 是曾经的“救赎”,企业 IT 生态现在面临的问题依然没有得到很好的解决。

作者介绍

耿立超,架构师,14 年 IT 系统开发和架构经验,对大数据、企业级应用架构、SaaS、分布式存储和领域驱动设计有丰富的实践经验,热衷函数式编程。目前负责企业数据中台的架构设计和开发工作,对 Hadoop/Spark 生态系统有深入和广泛的了解,参与过 Hadoop 商业发行版的开发,曾带领团队建设过数个完备的企业数据平台,个人技术博客:https://laurence.blog.csdn.net/ 作者著有《大数据平台架构与原型实现:数据中台建设实战》一书,该书已在京东和当当上线。

建设数据中台系列

企业数据能力测评:认清现状,布局未来丨建设数据中台系列(一)


怎么走着走着就变“烟囱”了呢?丨建设数据中台系列(二)


中台架构详解(上)丨建设数据中台系列(四)


中台架构详解(下)丨建设数据中台系列(五)


“数据中台”有何不同?丨建设数据中台系列(六)


“数据中台”怎么建?丨建设数据中台系列(七)


2020-08-06 10:443186

评论 3 条评论

发布
用户头像
SOA是架构思想,跟ESB、soap webservice这些实现技术手段无关。ESB、soap webservice过时了,SOA没有过时,微服务架构也是SOA的一种。
2020-08-07 11:21
回复
你说的也没错,但是我理解作者说的SOA是指狭义上的概念
2020-08-12 21:07
回复
SOA没有广义狭义之分,只是一直有很多人不理解SOA,把SOA和实现手段混在了一起。
2020-09-02 13:45
回复
没有更多了
发现更多内容

对Indexlookup的理解误区

TiDB 社区干货传送门

平安普惠湖北分公司:齐心抗疫显担当,助力小微迎暖春

科技新消息

平安普惠湖北分公司:疫情后来式,复工进行时

科技新消息

教你如何在优麒麟上调节外接显示器,如亮度、色彩等方面!

优麒麟

Linux 开源 经验分享 优麒麟 显示器

【二级等保】二级等保安全物理环境要求有哪些?

行云管家

网络安全 数据安全 等保 等级保护

云原生边缘计算KubeEdge在智慧停车中的实践

华为云原生团队

边缘计算 边缘技术 边缘云

这些大咖想和你聊聊什么是行业期待的多模态学习

小红书技术REDtech

算法 多模态

jackson学习之九:springboot整合(配置文件)

程序员欣宸

4月月更

ModStartCMS模块化建站系统 v3.7.0 栏目导航开关,页面样式优化

ModStart开源

基于 EventBridge 构建数据库应用集成

阿里巴巴云原生

投稿开奖丨轻量应用服务器征文活动(3月)奖励公布

阿里云弹性计算

轻量应用 征文投稿开奖

独家下载!突破开源Redis,华为云十年自研内核修炼之路《企业级Redis技术与应用解读》重磅发布丨云享·书库

华为云开发者联盟

redis 华为云 GaussDB(for Redis) 开源Redis 企业级Redis

Apache DolphinScheduler ASF 孵化器毕业一周年,汇报来了!

白鲸开源

Big Data DolphinScheduler workflow Open Source apache 社区

选择it资产管理软件要注意什么?

低代码小观

资产管理 企业管理系统 低代码开发 #资产追踪 客户关系管理系统

解构华为云HE2E项目中的容器技术应用

华为云开发者联盟

容器 镜像 华为云 devcloud HE2E

DIVE大会上线了!参与活动还有精美周边领取哦!

InfoQ写作社区官方

热门活动 DIVE

【首期社区读书会】从《OceanBase数据库系统概念》到3.1.3 社区新版本,一起聊聊 OceanBase 那些事

OceanBase 数据库

OceanBase 社区版

阿里巴巴云原生混部系统 Koordinator 正式开源

阿里巴巴云原生

【数字底座专题】星环科技春季新品发布周

星环科技

TASKCTL服务端字符界面的应用系统安装

敏捷调度TASKCTL

kettle 元数据 ETL 调度任务 大数据运维

【linux运维】linux运维常用工具有哪些?

行云管家

云计算 运维 IT运维 云管理

解决混合云数据库一站式备份若干问题 腾讯云数据库DBS正式上线

科技热闻

构建测试的体系化思维(高级篇)

BY林子

质量赋能 测试体系

Linux 命令行小技巧分享第二弹--超简单,超实用!

优麒麟

Linux 开源 命令行终端 实用技巧 优麒麟

知名数字化解决方案厂商新华三加入龙蜥社区,已完成硬件兼容性测试

OpenAnolis小助手

开源社区 兼容性测试 龙蜥社区 CLA 新华三

web技术支持| 简单实现Vue第一章:模板编译

anyRTC开发者

Vue 前端 Web 音视频 WebRTC

今天聊一聊合成数据 (Synthetic Data)

澳鹏Appen

人工智能 数据集 数据标注 数据训练 合成数据

CVE-2022-22965 漏洞分析,安全问题早发现

华为云开发者联盟

Java spring 漏洞 CVE JavaBean

优秀的FAQ示例及FAQ页面制作技巧

小炮

FAQ

移动数字化平台原来可以这样帮企业打造协同生态链!

BeeWorks

后端开发【一大波干货知识】网络通信模型和网络IO管理

Linux服务器开发

后端开发 Linux服务器开发 C++后台开发 网络io 网络通信

SOA为什么不“香”了?丨建设数据中台系列(三)_大数据_耿立超_InfoQ精选文章