- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我读过 Martin Fowler 的一篇文章“Microservices”,发现很难理解 智能端点 s 和 哑管 .请解释这些术语,欢迎举例。
最佳答案
我没有读过这篇文章,所以我只能推测他的确切含义,但是当他以 ESB 作为针对微服务的示例和 ZeroMQ 作为针对微服务的示例时,我希望我的推测非常准确:
Unix(和Linux)的思想之一是构建小的独立应用程序并通过管道连接它们。我使用的最常见的两个命令集可能是 ps
和 grep
像这样:ps aux | grep PROCESS_NAME
- 在这里你可以看到一个哑管道,它只转发 ps
的输出到 grep
的标准输入.
ZeroMQ 等其他消息传递系统的工作方式类似,尽管它们可能具有更多的复杂性,例如循环分发和可靠交付。 Erlang 作为一种语言建立在小型智能端点之上,在彼此之间发送消息。这里的优势很明显,文章中也提到过,小应用更容易维护,解耦更容易扩展。
另一方面,微服务是最常见的大型企业应用程序,例如前面提到的企业服务总线。我并没有真正与那些足以给你一个具体例子的工作,但通常这些总线包含许多功能,这些功能要么通过脚本要么配置包含。此类功能主要包括具有高级路由的可配置工作流,甚至可以转换消息,因此不同的端点可以处理它们。
一个例子可能是 - 如果您希望在系统中执行一些预先操作,例如更改已经运行的项目中的需求,这可以启动一个工作流,其中 ESB 将围绕这些更改的需求自动向不同的参与者发送不同的通知并等待 1 个或多个参与者确认,然后才会应用此更改。这基本上是相反的——哑端点(它只是向/从总线发送/接收数据)和一个非常智能的管道(总线,可以配置或编写脚本来处理所有可能的企业场景)。
我非常有信心存在处理类似场景的企业服务总线,这些总线与简单的“哑巴”类似 ZeroMQ 的消息传递框架相反。
基本上,逻辑必须在某处实现——要么在大 ESB 中,要么在端点中。微服务的想法是将其放入端点而不是总线,并具有与 unix 应用程序类似的理念。
关于architecture - 微服务:什么是智能端点和哑管道?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26616962/
如果您设计分布式应用程序以实现轻松扩展,或者您只想使用 Amazon、Google 或 Microsoft 提供的任何新的“云计算”产品,那么您通常最终会使用一些典型的概念或组件: 分布式 blob
根据uncle Bob's Clean Architecture 、企业和应用程序业务规则(概念上由命令组成)位于外部接口(interface)层之下的层中。因此,无论何时调用接口(interface
我在网上找不到它的任何实现实际上为您提供了一种与框架无关且实用的实现方式。 我已经看到了几个解决它的低于标准的建议: 使存储库方法成为原子 使用例原子化 它们都不是理想的。 案例#1 :大多数用例依赖
我正在查看 Sparkle 项目的配置并注意到它们设置: 架构 = ppc i386 x86_64 有效架构 = i386 x86_64 来自苹果的有效架构描述: Space-separated li
只听本周的podcast并认为将您的一些经验组合在一起会很好,在这些经验中,您已经看到设计的“架构”方面比应有的支配更多东西。 Java 在这方面经常受到负面报道,而且随着 Java EE 的复杂性增
我正在阅读 Bob Martin (https://blog.8thlight.com/uncle-bob/2012/08/13/the-clean-architecture.html) 的清洁架构
OSGi是模块化架构,JavaBeans是组件架构。有什么区别? 最佳答案 OSGi 和 Java Beans 之间的主要区别在于类加载器的工作方式。在标准 .jar 文件或 EJB 中,rt.jar
我对 Clean Architecture 中的 Gateway to Entity 依赖有疑问。我认为以下同心圆图形经常被介绍为整洁的架构。 在上图中,Gateway并没有直视Entity。但是,还
我试图理解 TOGAF 9 的核心概念。 无论我多长时间阅读 TOGAF 手册中的解释,我都无法理解 Enterprise Continuum 和 Architecture Repository 之间
如果 Kappa 架构直接对流进行分析,而不是将数据拆分为两个流,那么在像 Kafka 这样的消息系统中,数据存储在哪里?或者它可以在数据库中进行重新计算? 单独的批处理层是否比使用流处理引擎重新计算
它们的含义是什么,我可以将它们设置为不同的值吗? 最佳答案 架构是您想要构建的架构,有效的架构是您可以设想使用您的代码库构建的架构。 所以也许您只想为 armv7 构建二进制文件,但相同的源代码可以为
我现在正在尝试在 Xcode 4.0 中构建的项目遇到问题,希望有人可以为我解释一下。 我正在尝试使用 ZBar SDK 并遵循此处概述的指南中概述的说明: http://zbar.sourcefor
在基于 Apple Silicon 的机器上使用 Interface builder 时,我当前的项目会引发 IBDesignable 错误。 我尝试排除用于调试的 arm64 架构,以及我在互联网上
Xcode 项目中出现警告: crypto was rejected as an implicit dependency for 'libcrypto.a' because its architect
我正在 Xcode 5 中开始新项目。我想使用 iOS SDK 7 开发应用程序,但部署目标为 iOS 5.0。当我在 Xcode 中创建新项目并尝试将部署目标更改为 5.0 时,我收到了这条消息:
编辑 :这个问题可能是旧的,它与 xcode 3 有关。 我正在开发一个需要 voip 支持的 iPhone 应用程序,所以我添加了 pjsip 的 ARM 版本图书馆。但如果我使用 iPhone 模
我们最近将最低 iOS 支持设置为 4.0,并开始使用 LLVM 编译器对当前可用的应用程序进行新更新。 将“架构”和“有效架构”设置为仅 armv7 是否会排除 iPhone 3G 等 armv6
我想在我的 64 位机器上启用额外的架构(32 位)。我做了 dpkg --print-architecture 来了解已知的架构,即 amd64 。之后我做了 dpkg --print--forei
操作系统:OS X Yosemite 版本 10.10.1 XCode:未安装 应用程序加载器3.0 (620) PhoneGap:3.7.0 PhoneGap 构建:在线 (build.phoneg
我们已经构建了一个具有多个 native 绑定(bind)的 Xamarin 应用程序(iOS、Android)。该应用程序在设备和模拟器上运行良好,我们能够毫无问题地构建存档(显然)。 问题是当我们
我是一名优秀的程序员,十分优秀!