- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章事件驱动架构和微服务架构的区别与联系由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
我们生活在一个软件开发的新时代,一个云原生应用时代。为云交付而构建的应用程序必须具有高度可传输性、非常松散耦合、高度弹性和极快的响应能力。这要求很多。将今天的开发环境与之前的环境进行比较有助于解释所有这些是如何实现的.
微服务架构旨在将单个大型“单体”设计/系统分解为多个独立的组件/流程,从而使代码库更加细化和易于管理。甲微服务基本上是小的,松散耦合的分布式服务。它是更广泛的微服务架构的一部分,由一组松散耦合的微服务组成,这些微服务一起运行以解决一个共同的目标.
事件驱动架构(EDA)是一种解决耦合的方法,否则会在较大系统中的组件进行通信时发生(这就是微服务中发生的情况)。当微服务同步通信时,通过API调用,它们会变得相互依赖,导致系统难以维护。EDA通过使用事件代理作为中介,允许组件通过引发和响应事件进行通信来解决这个问题.
大多数给定应用程序都是作为单个代码块编写的。每个函数、每个布尔选项、每个重复或迭代过程以及应用程序调用的每个服务都包含在该代码中。每个服务、进程、函数、子例程和库之间的通信是代码处理中固有的.
在这样一个完整的单体应用程序中,如果代码中的任何地方出现任何问题,整个应用程序都会完全崩溃。程序错误……严重错误……致命错误……它们都不是令人愉快的,而且通常不容易解决.
如果任何服务中出现的缺陷会导致整个应用程序瘫痪,那么合乎逻辑的解决方案是通过单独和独立运行来隔离每个服务。任何服务中的故障只会导致该进程停止运行,而不是整个应用程序停止运行,整个应用程序将继续运行,直到重新实例化失败的服务并变为可用为止.
为了提高每个服务的隔离度,微服务在容器内的自己的进程中运行,该容器包括服务的代码、其配置、所有依赖项、库以及运行代码所需的其他资源。容器化服务可以单独测试并作为容器化镜像实例部署到主机操作系统.
将应用程序创建为独立容器化微服务的集合有几个显著的优势:
由于它们各自独立执行,因此每个微服务可以包含不同的代码——在不同的平台上创建不同的依赖项.
微服务、容器、DevOps、持续改进、持续开发和部署(CI/CD)、事件驱动架构(EDA)等都围绕实现更高的敏捷性而结合在一起.
容器中的每个微服务都独立于所有其他微服务,从而通过启用分段部署来提高应用程序的弹性。如果需要对任何特定微服务进行更改,则不需要重建甚至停止整个应用程序。这也允许简化维护.
开发者还可以享受分工协作,组成小团队来构建和维护特定的服务。他们甚至可以用任何语言构建这些服务,因为每个服务都与所有其他服务分开运行.
将所有这些结合在一起,容器化微服务符合敏捷性的核心概念。它们是非常松散耦合的,因此更改一个微服务不需要更改另一个。而且由于微服务易于复制,因此它们的可扩展性也很高。如果需要更改,只需修改需要更改的服务。容器实际上是应用服务粒度的定义.
传感事件驱动示意 。
一个简单的事件通常需要复杂的响应。所上图所求,房屋传感器检测到昂贵的戒指被盗的事件。诸如此类的事件处理器通过发出警报同时通知戒指的所有者和警察以便他们能够做出反应来提供必要的指导以提供威慑。这些通知中没有一个需要知道其他通知,也不需要在执行之前等待它们发生。此序列提供的即时操作展示了松散耦合的价值.
互连的容器化微服务可创建云原生应用程序,这些应用程序可轻松传输到网络上需要的任何位置。为了可靠和一致地运行,他们必须拥有一个能够自动执行所有潜在响应的通信平台(如:Istio).
经典的单体应用很难实现这一点,因为它们既不能很好地扩展,也不能提供所需的弹性。然而,云原生应用程序利用EDA使它们能够促进定义DevOps目标的敏捷性——在高度促进持续开发和部署的动态环境中实现持续改进.
总之,微服务和EDA是互补的,但也可以独立存在。微服务不必使用EDA构建。同样,EDA可以独立存在于不使用微服务的系统中,但随着云原生的推广应用,两者之间的关系越来越“亲密无间”.
原文链接:https://www.toutiao.com/a7033364225053524517/ 。
最后此篇关于事件驱动架构和微服务架构的区别与联系的文章就讲到这里了,如果你想了解更多关于事件驱动架构和微服务架构的区别与联系的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我们正在创建一个 n 层 Silverlight LOB 应用程序,并且正在考虑使用 .NET RIA 服务。我们不清楚这与我们当前的 WCF 服务 API 的关系在哪里。我们当前的架构是: 银光
上下文:我在celery + rabbitmq堆栈上有一个主工作系统。 系统已docker化(此处未提供worker服务) version: '2' services: rabbit:
我是 Windows Azure 新手,我正在尝试将我的 Web 应用程序部署到 Windows Azure。在我的应用程序中,我使用了一些 Web 服务,现在我想知道如何在 Windows Azur
因此,根据我对服务的了解,自定义对象似乎是写入服务以返回数据的方式。如果我正在编写将用于 1) 填充数据库或 2) 为网站提供信息的服务,是否有返回数据集/数据表而不是包含所有这些的自定义对象列表的用
我在 google 和 stackoverflow 上都找过答案,但似乎找不到。我正在尝试将 azure 实验的输出获取到应用程序。我使用 ibuildapp 和谷歌表单制作了该应用程序。如何使用 g
我不小心删除了 kubernetes svc: service "kubernetes" deleted 使用: kubectl delete svc --all 我该怎么办?我只是想删除服务,以便
我正在努力确定解决网络服务问题的最有效方法。 我的情况:我正在开发一个 Android 应用程序,它通过 Web 服务从 mysql 数据库(在我自己的服务器 PC 上)存储和检索数据。用户按下提交按
我一直在翻阅 Android 文档,我很好奇。什么时候绑定(bind)服务而不是不绑定(bind)服务?它提供了哪些优点/限制? 最佳答案 When would you bind a service
我试图从架构的角度理解 hive,我指的是 Tom White 关于 Hadoop 的书。 我遇到了以下关于配置单元的术语:Hive Services、hiveserver2、metastore 等。
我的问题:安装服务后我无法导航到基地址,因为服务不会继续运行(立即停止)。我需要在服务器或我的机器上做些什么才能使 baseAddress 有效吗? 背景:我正在尝试学习如何使用 Windows 服务
我正在努力就 Web 服务的正确组织做出决定。我应该有多个 ASMX 来代表 Web 服务中的不同功能,还是应该有一个 ASMX? 如果我有多个 ASMX,这不构成多个 Web 服务吗? 如果我只有一
我正在从事一个在 azure 平台上提供休息服务的项目。该服务由 iPhone 客户端使用,这是选择其余方法的重要原因之一。 我们希望通过 AccessControlService(ACS) 并使用
我是 Ionic 新手,正在使用 Ionic 3.9.2 我有几个终端命令来为我的 ionic 应用程序提供服务,但是,我没有发现这两个命令之间有任何区别。 ionic serve 和 ionic s
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
作为项目的一部分,我期待着问这个问题。我过去有开发和使用 Web 服务的经验,并且非常熟悉这些服务。但是,有人告诉我,作为下一个项目的一部分,我将需要使用“安全”的 Web 服务。您能否提供一些见解,
我浏览了很多关于这个问题的信息,但找不到解决方案。这里的问题是,我想使用 Apache Cordova 和 Visual Studio 连接到 wcf。因此,如果有人找到合适的工作解决方案,请发布链接
我在 Windows 服务中托管了一个 WCF(从 MS 网站示例中选取),我可以使用 SOAP UI 访问和调用方法。但是,当我尝试使用 jquery 从 Web 应用程序调用相同的方法时,我不断收
我们构建了一个 Android 应用程序,它从 Android 向我的 PHP 服务器发送 HTTP 请求。作为响应,Web 服务将 JSON 对象发送到 Android 应用程序以显示结果。 就像其
我想在 android 应用程序中调用 soap web 服务,它需要一个枚举值作为参数,它是一个标志枚举。如何从 Android 应用程序将一些值作为标志枚举传递给此 Web 服务方法? 我使用 K
我尝试在模拟器上安装 Google Play。我已按照 Google Dev Site 中的说明进行操作. 使用 ADV 管理器似乎没问题,设备的目标是 Google API 版本 22,但是当我运行
我是一名优秀的程序员,十分优秀!