当前位置: 首页 > news >正文

微服务、SOA 和 API 之间的区别

在软件开发中,组织的投资方式发生了重大转变,部署了面向架构的方法。这一切都始于 SOA,然后转变为我们称之为微服务的东西。添加到其中的是另一个概念,指定为 API。

在过去的几年里,SOA 和微服务仍然是讨论的话题。随着时间的推移,组织感到需要转变其工作流程并为其软件系统采用微服务。

首先,我们分别定义它们并找出差异所在。

您可能还喜欢: 微服务与 SOA:有什么区别?
微服务、SOA、API

不同的应用程序架构。
API 或应用程序编程接口
API 或应用程序编程接口是开发人员用于启动客户端和服务器之间通信的轻量级协议。API 的目的就是增加透明度,同时允许多个产品或服务相互交互。

最新的 DZone 参考卡

NoSQL 迁移要点


通过在 API 的帮助下添加不同的应用程序,可以轻松升级现有基础设施。当组织需要迁移到云或将其现有应用程序转移到云时,API 可以扩展支持。鉴于 API 的易用性,它可以帮助企业与 IT 团队协作,以便与云原生应用程序集成。这就是微服务概念出现的地方。

大多数云驱动的操作都基于微服务,并且它们使用 API 来连接到微服务。

根据 WSO2,API 现在占互联网流量的 25%。

当开发人员寻求将组织生态系统与云驱动的应用程序连接起来时,API 是最方便的方法之一。

API 的显着特征
概述确定两方连接方式的协议。
允许开发人员通过集成第三方服务来提高开发应用程序的生产力。
允许微服务与其他服务进行通信。
在当今的互联世界中,信息通过 API 共享给外部和内部团队,安全性是首要问题。API 提供对安全标准和安全需求的遵守。
SOA 或面向服务的架构
SOA 是一种面向企业的架构形式。它被视为软件开发的一种形式,其中应用程序的不同模块借助特定于网络的通信协议向另一个模块提供服务。现在,通信可以是任何内容,从传递单个参数到请求一条信息或协作多个服务。

SOA 主要强调由每个组件在独立环境中执行的单独功能的开发。它可以是验证付款或允许第三方登录等任何内容。

SOA架构图

SOA 架构元素
显然,面向服务的架构并不是模块化应用程序,而是连接或组合不同的服务来构建应用程序。简单来说,面向服务的架构更多的是提供服务,而不考虑事实和方式。

您也可以将它们视为微服务的简化版本。它们是松散耦合的,并使用企业总线消息传递协议来启动两个服务之间的通信。

根据 Gartner 的数据:

“SOA 减少了冗余并提高了可用性、可维护性和价值。这产生了更易于使用和维护的可互操作的模块化系统。SOA 创建更简单、更快的系统,从而提高敏捷性并降低总体拥有成本 (TCO)。”
随着时间的推移,精心设计的 SOA 会提高敏捷性。

SOA 的显着特征
SOA 是整体应用程序的粗粒度形式。
SOA 使用 IP 网络与不同的服务进行通信和连接。
SOA 支持多种消息协议,例如 AMQP、MSMQ 和 SOAP。
微服务
微服务作为一个通用术语,是一种软件开发方法,专注于开发模块或较小的应用程序块。稍后,这些可以在任何应用程序中独立部署,并在 API 的帮助下进行通信。与面向服务的架构(使用企业级消息传递协议,特别是 IP)不同,微服务诱导 API 与不同的模块连接。

马丁·福勒名言

换句话说,微服务允许开发人员创建更小的服务,然后将每个服务组合起来作为单个应用程序紧密地工作。将整个应用程序开发为一个独立的概念显得非常繁琐,而微服务减轻了开发人员的任务,使他们能够独立地处理单独的模块,然后集成所有服务以形成应用程序。

每个模块或构建的服务都能够运行自己的进程。这些服务可以与使用轻量级协议(称为 API)的任何其他服务集成。正是这些 API 使两个微服务能够相互通信。

例如,假设您有一个医疗保健门户,并且想要添加一个身份验证页面。您可以做的是创建一个专门用于身份验证的独特应用程序,然后使用任何类型的通信协议将其集成到现有基础设施中。

微服务架构图

微服务架构
微服务的显着特征
微服务消除了集中治理的概念。
允许开发人员构建可以独立运行的较小模块。
允许团队分别处理不同的服务,然后根据需要重新组合它们。
微服务是颗粒化的 SOA。
微服务通常部署在容器中。
当我们将这三者放在一起考虑时,我们知道 API 是开发人员用来启动两个服务或应用程序之间的通信的协议或标准。

兰迪·赫夫纳名言

主要区别 — SOA 与微服务
SOA 是服务驱动的,重点是最大限度地提高服务的可重用性。相反,微服务遵循分散式方法,其中整个应用程序在单独的组件中解耦,每个组件都可以在独立环境中单独使用。
SOA 利用企业总线消息传递协议来促进两个干预方之间的通信,而微服务则领先一步,使用 API 在两个组件之间进行通信。
SOA 旨在增强应用程序的可重用性,遵循尽可能多的共享方法。虽然微服务也可以重用,但它促进了解耦组件来构建不同的应用程序,遵循尽可能少的共享方法。
对于 SOA,应用程序中的任何更改或修改都需要更新整个整体。但对于部署微服务的组织来说,新功能需要新的服务集成。
SOA 使用多种消息传递协议,而微服务更倾向于安全方面,因此嵌入 API、https 等轻量级协议。
共享相同数据存储的服务容易遭受数据泄露。另一方面,微服务为每个应用程序部署独立的数据库,保持所存储信息的完整性。此外,这还有助于提高性能和规模。
SOA 提倡共享多个组件,这会导致数据依赖性的产生。微服务将每个组件耦合成一个独立的单元。这加快或提高了使用微服务构建的系统的速度。当然,这对于投资 SOA 的组织来说是一个很大的缺点。反过来,微服务具有更好的上市时间优势。
微服务是更小的组件,每个组件都旨在实现单一目的。SOA 的规模更大,并且涉及的组件满足多种功能。微服务是更小的组件,使其更易于维护。

相关文章:

微服务、SOA 和 API 之间的区别

在软件开发中,组织的投资方式发生了重大转变,部署了面向架构的方法。这一切都始于 SOA,然后转变为我们称之为微服务的东西。添加到其中的是另一个概念,指定为 API。 在过去的几年里,SOA 和微服务仍然是讨论的话题。随…...

python打印正反直角三角形

我们用while循环&#xff0c;第一行打印一颗星&#xff0c;第二行打印两颗星&#xff0c;依次循环到五颗 我们写while循环时&#xff0c;先定义一个变量&#xff0c;然后在循环中增加值 i0 while < 5:j0while j <i:print(*,end\t)j1print() # 换行i1我们还可以打印反…...

ubuntu安装Miniconda并举例使用

更新系统包 sudo apt update sudo apt upgrade官网下载Miniconda&#xff0c;最好是实体机下载后放进虚拟机&#xff0c;方法可以参考Xftp 7连接服务器或者本地虚拟机文章 https://docs.conda.io/en/latest/miniconda.html#linux-installers 进入安装目录执行&#xff0c;右键…...

如何保护您的数据免受.360勒索病毒的感染

导言&#xff1a; 网络安全漏洞和威胁伴随着我们的日常生活。其中&#xff0c; 360 勒索病毒成为了引发广泛关注的网络威胁之一。本文91数据恢复将深入探索 360 勒索病毒&#xff0c;揭示它背后的黑暗故事和如何防范此类风险。 如果受感染的数据确实有恢复的价值与必要性&#…...

2024计算机保研--哈工大、中山、国防科大

前言 标题中的学校是我在九月前差不多拿到 o f f e r offer offer&#xff0c;且有可能会去的学校&#xff0c;这篇博客也不能算是经验贴&#xff0c;只能算是血泪史吧。趁着我还记得这几个月的经历&#xff0c;还是记录一下吧&#xff0c;刚才刷知乎看了七月哥&#xff08;是…...

Hadoop分布式集群搭建教程

目录 前言环境准备一、创建虚拟机二、虚拟机网络配置三、克隆虚拟机四、Linux系统配置五、Hadoop的部署配置六、Hadoop集群的启动 前言 大数据课程需要搭建Hadoop分布式集群&#xff0c;在这里记录一下搭建过程 环境准备 搭建Haoop分布式集群所需环境&#xff1a; VMware&a…...

学习函数式编程、可变参数及 defer - GO语言从入门到实战

函数是⼀等公⺠、学习函数式编程、可变参数及 defer - GO语言从入门到实战 函数是⼀等公⺠ 在Go语言中&#xff0c;函数可以分配给一个变量&#xff0c;可以作为函数的参数&#xff0c;也可以作为函数的返回值。这样的行为就可以理解为函数属于一等公民。 与其他主要编程语⾔…...

Linux 文件链接

Linux 下的文件链接有两类。一个是类似于 win 电脑的快捷方式&#xff0c;我们称为软链接&#xff0c;软链接也可以叫做符号链接。另一种是通过文件系统的 inode 连接来产生的&#xff0c;类似于 windows 电脑的复制&#xff0c;但是不产生新的文件&#xff0c;我们称为硬链接。…...

1.go web之gin框架

Gin框架 一、准备 1.下载依赖 go get -u github.com/gin-gonic/gin2.引入依赖 import "github.com/gin-gonic/gin"3. &#xff08;可选&#xff09;如果使用诸如 http.StatusOK 之类的常量&#xff0c;则需要引入 net/http 包 import "net/http"二、基…...

工程物料管理信息化建设(十二)——关于工程物料管理系统最后的思考

目录 1 功能回顾1.1 MTO模块1.2 请购模块1.3 采购模块1.4 催交模块1.5 现场管理模块1.6 数据分析和看板模块1.7 其它模块 2 最后几个问题2.1 按管线发料和直接发料重叠2.2 YHA 材料编码的唯一性问题2.3 “合同量单-箱单-入库单” 数据映射 3 关于未来的思考3.1 三个专业之间的关…...

什么是API网关?——驱动数字化转型的“隐形冠军”

什么是API网关 API网关&#xff08;API Gateway&#xff09;是一个服务器&#xff0c;位于应用程序和后端服务之间&#xff0c;提供了一种集中式的方式来管理API的访问。它是系统的入口点&#xff0c;负责接收并处理来自客户端的请求&#xff0c;然后将请求路由到相应的后端服…...

Java 序列化和反序列化为什么要实现 Serializable 接口?

序列化和反序列化 序列化&#xff1a;把对象转换为字节序列的过程称为对象的序列化. 反序列化&#xff1a;把字节序列恢复为对象的过程称为对象的反序列化. 什么时候需要用到序列化和反序列化呢或者对象序列化的两种用途… &#xff1a; (1) 对象持久化&#xff1a;把对象的…...

【【萌新的SOC学习之GPIO学习 水】】

萌新的SOC学习之GPIO学习 General Purpose I/O 通用I/O zynq-7000 SOC PS 分为四大部分 APU application Processor UintMemoryIO外设Interconnect 内部互联 PL &#xff1a; IO外设 GPIO可以连接通用的设备&#xff08;比如按键&#xff09; 也可以用GPIO模拟其他的协议 GP…...

10-Node.js入门

01.什么是 Node.js 目标 什么是 Node.js&#xff0c;有什么用&#xff0c;为何能独立执行 JS 代码&#xff0c;演示安装和执行 JS 文件内代码 讲解 Node.js 是一个独立的 JavaScript 运行环境&#xff0c;能独立执行 JS 代码&#xff0c;因为这个特点&#xff0c;它可以用来…...

Redis 的过期键 | Navicat 技术干货

Redis 是一种高性能的内存数据存储&#xff0c;以其速度和多功能性而闻名。其中一个有用的特性是为键设置过期时间的功能。在 Redis 中&#xff0c;为键设置过期时间对于管理数据和确保过时或临时数据自动从数据库中删除是至关重要的。在本文中&#xff0c;我们将探讨在 redis-…...

IDC服务器商是如何保护服务器的数据安全

服务器是作为一个公司存储数据和管理服务的设备&#xff0c;随着网络的不断发展大数据的普遍性&#xff0c;所以数据安全问题也越来越受到企业和个体的重视&#xff0c;那么IDC服务器商家是如何对服务器的数据进行安全保护的呢&#xff1f; 配置防火墙。防火墙是服务器的必备工…...

c++中什么时候用double?

c中什么时候用double? 在C中&#xff0c;通常使用double数据类型来表示浮点数&#xff0c;特别是当需要更高的精度时。以下是一些情况下可以考虑使用double的示例&#xff1a; 1. **需要高精度的计算**&#xff1a;当您需要进行精确的浮点数计算时&#xff0c;double通常比flo…...

TCP/IP(四)TCP的连接管理(一)三次握手

一 tcp连接回顾 部分内容来自小林coding TCP篇 记录的目的&#xff1a; 亲身参与进来,加深记忆 ① 引入 前面我们知道&#xff1a; TCP 是面向连接 [点对点的单播]的、可靠的、基于字节流的传输层通信协议面向连接意味着&#xff1a;在使用TCP之前,通信双方必须先建立一…...

bash上下键选择选项demo脚本

效果如下&#xff1a; 废话不多说&#xff0c;上代码&#xff1a; #!/bin/bashoptions("111" "222" "333" "444") # 选项列表 options_index0 # 默认选中第一个选项 options_len${#options[]}echo "请用上下方向键进行选择&am…...

cf 1886A

题目是输入一个数字&#xff0c;分解成三个数字的和&#xff0c;这三个数字都不相同&#xff0c;并且都不可以被三整除&#xff0c;如果存在输出YES并且输出任意一组可能的三个数字&#xff0c;否则输出NO 代码 #include<bits/stdc.h> using namespace std;int main() …...

逻辑回归:给不确定性划界的分类大师

想象你是一名医生。面对患者的检查报告&#xff08;肿瘤大小、血液指标&#xff09;&#xff0c;你需要做出一个**决定性判断**&#xff1a;恶性还是良性&#xff1f;这种“非黑即白”的抉择&#xff0c;正是**逻辑回归&#xff08;Logistic Regression&#xff09;** 的战场&a…...

linux arm系统烧录

1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 &#xff08;忘了有没有这步了 估计有&#xff09; 刷机程序 和 镜像 就不提供了。要刷的时…...

srs linux

下载编译运行 git clone https:///ossrs/srs.git ./configure --h265on make 编译完成后即可启动SRS # 启动 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/srs.log 开放端口 默认RTMP接收推流端口是1935&#xff0c;SRS管理页面端口是8080&#xff0c;可…...

ArcGIS Pro制作水平横向图例+多级标注

今天介绍下载ArcGIS Pro中如何设置水平横向图例。 之前我们介绍了ArcGIS的横向图例制作&#xff1a;ArcGIS横向、多列图例、顺序重排、符号居中、批量更改图例符号等等&#xff08;ArcGIS出图图例8大技巧&#xff09;&#xff0c;那这次我们看看ArcGIS Pro如何更加快捷的操作。…...

uniapp 字符包含的相关方法

在uniapp中&#xff0c;如果你想检查一个字符串是否包含另一个子字符串&#xff0c;你可以使用JavaScript中的includes()方法或者indexOf()方法。这两种方法都可以达到目的&#xff0c;但它们在处理方式和返回值上有所不同。 使用includes()方法 includes()方法用于判断一个字…...

解读《网络安全法》最新修订,把握网络安全新趋势

《网络安全法》自2017年施行以来&#xff0c;在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂&#xff0c;网络攻击、数据泄露等事件频发&#xff0c;现行法律已难以完全适应新的风险挑战。 2025年3月28日&#xff0c;国家网信办会同相关部门起草了《网络安全…...

Leetcode33( 搜索旋转排序数组)

题目表述 整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 。 在传递给函数之前&#xff0c;nums 在预先未知的某个下标 k&#xff08;0 < k < nums.length&#xff09;上进行了 旋转&#xff0c;使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nu…...

小木的算法日记-多叉树的递归/层序遍历

&#x1f332; 从二叉树到森林&#xff1a;一文彻底搞懂多叉树遍历的艺术 &#x1f680; 引言 你好&#xff0c;未来的算法大神&#xff01; 在数据结构的世界里&#xff0c;“树”无疑是最核心、最迷人的概念之一。我们中的大多数人都是从 二叉树 开始入门的&#xff0c;它…...

GraphQL 实战篇:Apollo Client 配置与缓存

GraphQL 实战篇&#xff1a;Apollo Client 配置与缓存 上一篇&#xff1a;GraphQL 入门篇&#xff1a;基础查询语法 依旧和上一篇的笔记一样&#xff0c;主实操&#xff0c;没啥过多的细节讲解&#xff0c;代码具体在&#xff1a; https://github.com/GoldenaArcher/graphql…...

Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解

文章目录 1. 题目描述1.1 链表节点定义 2. 理解题目2.1 问题可视化2.2 核心挑战 3. 解法一&#xff1a;HashSet 标记访问法3.1 算法思路3.2 Java代码实现3.3 详细执行过程演示3.4 执行结果示例3.5 复杂度分析3.6 优缺点分析 4. 解法二&#xff1a;Floyd 快慢指针法&#xff08;…...