到底是微服务,还是SOA?

在这里插入图片描述

引言:大概正式工作有5年了,换了三个大厂【也是真特么世道艰难,中国互联网人才饱和了】。基本上每个公司有的架构都不太相同,干过TOC和TOB的业务,但是大家用的架构都不太相同。有坚持ALL in one的SB,最后服务像一坨xx。也有微服务的狂热爱好者,最后服务多的自己都数不清,之间的关联乱七八糟,一个功能穿八九个微服务情况。其实选什么,主要是根据业务来决定的,盲目的选择就会成为一坨xx。


目录

  • 1.SOA介绍
    • 1.1 SOA架构的定义
    • 1.2 SOA架构的特点
    • 1.3 SOA架构的组成部分
    • 1.4 SOA架构的实现技术
    • 1.5 SOA架构的优点
    • 1.6 SOA架构的缺点
    • 1.7 SOA架构的应用场景
  • 2 微服务介绍
    • 2.1 微服务架构的定义与本质
    • 2.2 微服务架构的特点
    • 2.3 微服务架构的组件
    • 2.4微服务架构的优缺点
      • 2.4.1 优点
      • 2.4.2 缺点
    • 2.5 微服务架构的应用场景
  • 3 选择SOA还是微服务?
    • 3.1 项目需求与规模
    • 3.2 技术栈与团队能力
      • 3.3 部署与运维
      • 3.4 可扩展性与灵活性
    • 3.5 其他考虑因素


1.SOA介绍

SOA(Service-Oriented Architecture),即面向服务的架构,是一种在计算机环境中设计、开发、部署和管理离散模型的方法。以下是对SOA架构的详细解析:

1.1 SOA架构的定义

SOA架构将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的接口和契约联系起来。接口是采用中立的方式进行定义的,它应该独立于实现服务的硬件平台、操作系统和编程语言。这使得构建在各种这样的系统中的服务可以以一种统一和通用的方式进行交互。

1.2 SOA架构的特点

  1. 粗粒度:服务数量不应太多,依靠消息交互而不是远程过程调用。
  2. 松耦合:减少各个服务间的相互依赖和影响,各个服务的位置、实现技术、当前状态以及私有数据,对服务请求者不可见。
  3. 标准化:SOA架构中的服务接口和通信协议通常是标准化的,如SOAP、REST等,这有助于不同平台和技术之间的服务进行互操作。

1.3 SOA架构的组成部分

  1. 服务提供者:发布服务,并且对使用自身服务的请求进行响应。
  2. 服务请求者:利用服务,应用程序通过服务请求者来调用或者请求服务。
  3. 服务注册中心:注册已发布的服务,对其进行分类,并提供搜索服务。

1.4 SOA架构的实现技术

  1. Web Service:基于SOAP等协议实现服务之间的通信。
  2. 服务注册表:如UDDI(Universal Description Discovery and Integration),提供服务的注册、查找和定位功能。
  3. 企业服务总线(ESB):将企业中各个不同的服务连接在一起,屏蔽异构系统对外提供的不同接口,实现服务间高效的互联互通。

1.5 SOA架构的优点

  1. 提高系统的可扩展性和灵活性:SOA架构将系统拆分成独立的服务,可以按需组合和重组这些服务,从而实现系统的快速扩展和灵活部署。
  2. 提高系统的可重用性:每个服务都是独立的功能单元,可以在不同的系统中复用,提高了系统的开发效率。
  3. 降低系统的耦合性:SOA架构通过服务之间的松耦合关系,降低了服务之间的依赖性,有利于系统的模块化和维护。
  4. 提高系统的稳定性和可靠性:SOA架构采用了服务注册与发现机制、负载均衡、故障恢复等机制,提高了系统的稳定性和可靠性。

1.6 SOA架构的缺点

  1. 系统复杂度高:SOA架构中涉及多个服务之间的协作和通信,系统的复杂度较高,开发、测试和维护成本相对较高。
  2. 性能问题:由于服务之间的通信需要通过网络进行,可能存在网络延迟和性能损失,对系统的性能造成影响。
  3. 安全性难以保障:SOA架构中涉及多个服务之间的通信,需要对数据传输进行加密和安全控制,保障系统的安全性比较困难。
  4. 部署和运维难度大:SOA架构中涉及多个服务的部署和管理,需要专门的运维团队进行管理,增加了系统的复杂性和运维成本。

1.7 SOA架构的应用场景

  1. 企业应用集成(EAI):通过封装应用程序为服务并通过服务接口进行通信,实现数据的共享和业务流程的整合。
  2. 业务流程管理(BPM):通过组合不同的服务来实现灵活的业务流程管理和自动化。
  3. 微服务架构:SOA框架可以作为构建和管理微服务架构的基础设施。
  4. 云计算和云服务:通过封装应用程序为云服务,实现跨平台和跨组织的服务交付。
  5. 移动应用开发:用于构建后端服务,提供数据和功能的访问接口。
  6. 电子商务和电子支付:通过服务的方式实现商家和消费者之间的交互和支付功能。
  7. 物联网(IoT):帮助实现设备和传感器之间的数据交换和通信。

2 微服务介绍

微服务架构(Microservice Architecture)是一种将大型单个应用程序和服务拆分为数个甚至数十个小型支持服务的架构风格,每个小型服务都独立地进行开发、管理和迭代。以下是对微服务架构的详细解析:

2.1 微服务架构的定义与本质

微服务架构围绕业务领域组件来创建应用,这些应用可独立地进行开发、管理和迭代。在分散的组件中使用云架构和平台式部署、管理和服务功能,使产品交付变得更加简单。其本质是用一些功能比较明确、业务比较精练的服务去解决更大、更实际的问题。

2.2 微服务架构的特点

  1. 独立性:每个微服务都是独立的,可以独立开发、测试、部署和扩展,不受其他服务的限制。这种独立性提高了各个服务的可维护性和可重用性。
  2. 轻量级通信:微服务之间通过轻量级通信机制(如RESTful API)进行交互,使得服务之间的通信更加快速和高效。这有助于提高系统的可扩展性和响应速度。
  3. 灵活性和可扩展性:微服务架构使得应用更加灵活和可扩展,可以根据市场需求快速调整和优化。通过将应用拆分为一系列独立的微服务,可以更加方便地添加或修改功能。
  4. 高可用性:每个微服务都可以有多个实例运行,当某个服务出现故障时,其他服务可以继续正常运行,提高了系统的可用性。这有助于保证系统的稳定性和可靠性。
  5. 便于维护和升级:每个微服务都是独立的,便于进行维护和升级,同时也可以根据需要进行替换。这有助于提高系统的可维护性和可升级性。
  6. 去中心化:微服务架构采用去中心化思想,服务之间采用RESTful等轻量协议通信,相比传统的ESB(Enterprise Service Bus)更轻量。这有助于减少系统的复杂性,提高系统的可扩展性和灵活性。

2.3 微服务架构的组件

微服务架构通常包含以下关键组件:

  1. 服务注册与发现:如Eureka、Consul等,用于实现微服务的动态注册和发现功能,使得服务之间能够相互找到并进行通信。
  2. 负载均衡:如Ribbon、Nginx等,用于在微服务之间分配请求,提高系统的吞吐量和响应速度。
  3. API网关:如Zuul、Spring Cloud Gateway等,作为外部请求与内部微服务之间的桥梁,提供安全控制、流量管理、协议转换等功能。
  4. 配置中心:如Spring Cloud Config、Apollo等,用于集中管理微服务的配置文件和参数,实现配置的动态更新和版本管理。
  5. 服务熔断与降级:如Hystrix等,用于在微服务之间出现调用异常时,进行熔断处理,防止故障扩散,并提供降级策略,保证系统的稳定性。
  6. 监控与日志:如ELK(Elasticsearch、Logstash、Kibana)堆栈、Prometheus和Grafana等,用于收集和分析微服务的日志和性能指标,提供实时监控和报警功能。

2.4微服务架构的优缺点

2.4.1 优点

  1. 技术栈灵活:每个微服务都可以使用不同的编程语言、框架和技术栈来实现,提高了开发的灵活性和效率。
  2. 易于扩展和升级:由于每个微服务都是独立的,因此可以单独进行扩展和升级,降低了系统的复杂性和风险。
  3. 故障隔离:微服务之间的独立部署和运行,使得某个服务的故障不会影响到其他服务的正常运行,提高了系统的可靠性和稳定性。

2.4.2 缺点

  1. 部署和运维复杂:微服务架构需要管理多个服务单元,每个服务单元都需要部署、监控和管理,增加了运维的复杂性和成本。
  2. 网络延迟和错误:微服务之间的通信需要通过网络进行,可能会受到网络延迟和错误的影响,导致系统的响应时间和可靠性下降。
  3. 数据一致性难以保证:由于每个微服务都独立运作,需要在服务之间保持数据一致性,这可能需要使用分布式事务或基于事件驱动的架构等复杂的技术手段来实现。

2.5 微服务架构的应用场景

微服务架构适用于以下多种应用场景:

  1. 大型复杂企业应用:如企业资源规划(ERP)系统、客户关系管理(CRM)系统等,通过微服务架构可以将其拆分为多个独立的服务,提高系统的灵活性和可维护性。
  2. 电子商务平台:需要处理大量的用户请求和交易数据,通过微服务架构可以将其拆分为商品管理、订单管理、支付、物流等多个服务,提高平台的性能和可靠性。
  3. 社交网络平台:需要处理大量的用户交互和数据存储,通过微服务架构可以将其拆分为用户管理、消息服务、朋友圈服务、推荐服务等多个服务,提高平台的灵活性和可扩展性。
  4. 金融系统:如银行核心系统、保险核心系统等,通过微服务架构可以将其拆分为账户管理、交易处理、风险管理、报表服务等多个服务,提高系统的性能和可靠性。

3 选择SOA还是微服务?

从上面的介绍来看,其实就可以总结出来,SOA是面向服务的一种架构,微服务是面向功能点的一种架构。论服务之间依赖的复杂度,SOA是低于微服务的;但是论服务本身的复杂度,微服务是远低于SOA的。

在选择微服务架构和SOA(Service-Oriented Architecture,面向服务的架构)时,需要依据项目的具体需求、组织的技术栈、团队的实际情况以及未来的可扩展性等多个因素进行权衡。以下是一些关键的考虑因素:

3.1 项目需求与规模

  1. 项目规模
    • 对于大型企业级应用,SOA可能更适合,因为它可以将整个企业的功能划分为一组自治的服务,这些服务通常较大且功能较为复杂。
    • 对于小型或中型应用,或者需要快速迭代和敏捷开发的项目,微服务架构可能更为合适,因为它将应用程序划分为一组小型、独立的服务,每个服务都专注于一个特定的业务功能。
  2. 业务需求变化
    • 如果业务需求经常变化,微服务架构的灵活性更高,可以更快地适应需求的变化。
    • 如果业务需求相对稳定,SOA架构也能满足需求,但可能在灵活性方面稍逊于微服务。

3.2 技术栈与团队能力

  1. 技术栈
    • 如果团队已经熟悉SOA架构及其相关技术(如SOAP、WSDL、ESB等),并且这些技术在当前项目中具有优势,那么选择SOA可能更为合适。
    • 如果团队对微服务架构及其相关技术(如Spring Boot、Docker、Kubernetes等)更为熟悉,或者希望采用更现代、更灵活的技术栈,那么微服务架构可能更为合适。
  2. 团队能力
    • 微服务架构需要团队具备分布式系统开发、容器化技术、持续集成/持续部署(CI/CD)等方面的能力。
    • SOA架构则可能需要团队具备Web服务开发、企业服务总线(ESB)管理等方面的能力。

3.3 部署与运维

  1. 部署复杂性
    • 微服务架构的每个服务都可以独立部署和扩展,这使得部署过程更加灵活和高效。
    • SOA架构中的服务通常较大且功能较复杂,因此部署和扩展可能相对较为复杂。
  2. 运维成本
    • 微服务架构的运维成本可能较高,因为需要管理多个独立的服务单元和它们之间的通信。
    • SOA架构的运维成本可能相对较低,因为服务之间的通信通常通过企业服务总线(ESB)进行集中管理。

3.4 可扩展性与灵活性

  1. 可扩展性
    • 微服务架构更容易实现水平扩展,因为每个服务都可以独立地增加或减少实例数。
    • SOA架构的可扩展性可能受到服务之间依赖关系的限制。
  2. 灵活性
    • 微服务架构的灵活性更高,可以更快地适应市场和技术变化。
    • SOA架构在灵活性方面可能稍逊于微服务,但也能满足大多数企业级应用的需求。

3.5 其他考虑因素

  1. 安全性
    • 无论是微服务架构还是SOA架构,都需要关注安全性问题,包括服务之间的通信安全、数据保护等。
  2. 监控与日志
    • 微服务架构需要更复杂的监控和日志系统来跟踪和管理多个独立的服务。
    • SOA架构的监控和日志系统可能相对简单一些,因为服务之间的通信通常通过ESB进行集中管理。

总结下来就这么几句话:

  1. 追求性能,且服务的流量比较大,选择微服务比较合适;服务流量比较小,选择SOA更划算
  2. 面向业务的体量,如果是体量较大,功能点比较多的业务,选择SOA比较合适;反之业务简单,体量较小,选择微服务比较合适。

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

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

相关文章

2024项目管理软件,不融入敏捷开发怎么行?

一、项目管理软件的重要性 在当今快节奏的商业环境中,项目管理软件的重要性愈发凸显。随着市场竞争的不断加剧,企业面临着越来越多的挑战,项目的复杂性和不确定性也在不断增加。在这样的背景下,项目管理软件成为了团队高效规划、…

大模型涌现判定

什么是大模型? 大模型:是“规模足够大,训练足够充分,出现了涌现”的深度学习系统; 大模型技术的革命性:延申了人的器官的功能,带来了生产效率量级提升,展现了AGI的可行路径&#x…

◇【论文_20151120_20160405v3】Dueling Network 决斗〔Google DeepMind〕

整理代码:Dueling_DQN__Pendulum_v1.ipynb https://arxiv.org/abs/1511.06581 Dueling Network Architectures for Deep Reinforcement Learning 文章目录 摘要1. 引言1.1. 相关工作 2. 背景2.1. Deep Q-networks 【DQN】2.2. Double Deep Q-networks 【DDQN】2.3…

Linux基础项目开发day05:量产工具——页面系统

文章目录 一、数据结构抽象page_manager.h 二、页面管理器page_manager.c 三、单元测试1、main.page.c2、page_test.c3、Makefile修改3.1、unittest中的Makefile3.2、page中的Makefile 四、上机实验 前言 前面实现了显示、输入、文字、UI系统,现在我们就来实现页面的…

HCIP--1实验DNS,VLAN,静态路由,浮动静态,动态路由协议,Telnet

学习目标: 静态路由,浮动静态 VLAN,vlan间路由TelnetACL NAT OSPF/RIP 学习内容: 实验拓扑实验需求实验需求分析实验配置内容 (每一个设备的每一步操作)实验结果验证 1.实验拓扑 2.实验需求 1,学校内部…

Qt键盘按下事件和定时器事件及事件的接收和忽略

定时器事件 //设置多少毫秒调用一次 1s1000timerId this->startTimer(1000);timerId2 this->startTimer(500);void MyWidget::timerEvent(QTimerEvent* t) {static int sec 0;//通过判断当前ID来实现不同定时器的调用时间if(t->timerId() this->timerId){//隔一…

IDEA中的快捷键大全--超详细

目录 一、通用类型 1.1 图示 1.2 表格化 二、编写速度提升 2.1 图示 2.1.1 表格化 2.2 图示 2.2.1 表格化: 三、类结构,查找和查看源码 3.1 图示 3.2 表格化 四、查找,替换和关闭 4.1图示 4.2 表格化 五、调整格式 5.1 图示 5.2 表格化 六、快捷键的自主定义…

【C】数组(array)

数组(array) 数组的概念 数组是一组相同类型元素的集合 数组中存放的是1个或者多个数据,但是数组元素个数不能为0数组中存放的多个数据,类型是相同的 数组分为一维数组和多维数组,多维数组一般比较多见的是二维数组 一维数组的创建和初始…

递归神经网络解释(RNN)

Recurrent Neural Network (RNN) 如今,不同的机器学习技术用于处理不同类型的数据。最难处理和预测的数据类型之一是顺序数据。顺序数据与其他类型的数据不同,因为虽然可以假设典型数据集的所有特征都是与顺序无关的,但不能假设顺序数据集是无关的。为了处理这种类型的数据…

Kibana可视化Dashboard如何基于字段是否包含某关键词进行过滤

kinana是一个功能强大、可对Elasticsearch数据进行可视化的开源工具。 我们在dashboard创建可视化时,有时需要将某个index里数据的某个字段根据是否包含某些特定关键词进行过滤,这个时候就可以用到lens里的filter功能很方便地进行操作。 如上图所示&…

【笔记】【YOLOv10图像识别】自动识别图片、视频、摄像头、电脑桌面中的花朵学习踩坑

(一)启动 创建环境python3.9 打开此环境终端 (后面的语句操作几乎都在这个终端执行) 输入up主提供的语句:pip install -r requirements.txt 1.下载pytorch网络连接超时 pytorch网址: Start Locally | P…

centos系列图形化 VNC server配置,及VNC viewer连接,2024年亲测有效

centos系列图形化 VNC server配置,及VNC viewer连接 0.VNC服务介绍 VNC英文全称为Virtual Network Computing,可以位操作系统提供图形接口连接方式,简单的来说就是一款桌面共享应用,类似于qq的远程连接。该服务是基于C/S模型的。…

【STM32-HAL库】STM32F系列新建工程并点灯教程(小白向)

本帖是STM32HAL库系列新建工程系列合集 stm32-HAL库cubeMX新建工程教程(以F103C8T6为例)https://blog.csdn.net/qq_39150957/article/details/136637881?fromshareblogdetail&sharetypeblogdetail&sharerId136637881&sharereferPC&sha…

uniapp使用html2canvas时,页面内的image元素模糊

不废话很简单只需要将image改成img就行 改之前 改之后 原因可能是因为uniapp里面的image标签做了某种处理

[已解决]DockerTarBuilder永久解决镜像docker拉取异常问题

前阵子发现阿里云的docker加速镜像失效了(甚至连nginx都拉取不了),重新换了并且加多了网络上比较常用的dokcer加速源,可以解决一部分问题,但仍然有一些镜像的某个版本或一些比较冷的镜像就是拉取不了,原因未…

Spring Security 基础配置详解(附Demo)

目录 前言1. 基本知识2. Demo3. 实战 前言 基本的Java知识推荐阅读: java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)【Java项目】实战CRUD的功能整理(持续更新) 1. 基本知识 HttpSecurity 是 Spri…

51单片机快速入门之 LCD1602 液晶显示屏2024/10/19

51单片机快速入门之 LCD1602 液晶显示屏 Proteus 电路图 : 74HC595 拓展电路可以不用,给 p0-p17 添加上拉电阻也可以!,我这里是方便读取和节省电阻线路 (因为之前不知道 在没有明确循环的情况下,Keil编译器可能会在main()中自动添加类似以下的汇编代码&#xff1a…

ChatGPT Plus 升级全攻略

ChatGPT Plus 升级全攻略 最近有很多人想知道如何顺利升级到 ChatGPT Plus。这里有详细步骤,确保你不会错过任何环节。 第一步:登录 OpenAI 首先,你需要去 chat.openai.com。 然后,点击“登录”,输入你的邮箱和密码。 接下来,确保你输入的信息是正确的。 第二步:点击“升级…

HttpURLConnection构造请求体传文件

HttpURLConnection构造请求体传文件 在Java中,使用HttpURLConnection构造请求体传输文件,你需要做以下几步: 1、创建URL对象指向你想要请求的资源。 2、通过URL打开连接,转换为HttpURLConnection实例。 3、设置请求方法为POST。 …

软件测试工程师:如何写出好的测试用例?

软件测试用例(Test Case)是软件测试过程中的一种详细文档或描述,用于描述在特定条件下,对软件系统或组件进行测试的步骤、输入数据、预期输出和预期行为。编写高质量的测试用例是确保软件质量的关键步骤之一。以下是一些编写优秀测试用例的建议&#xff…