高级系统架构师必知的经纪人Broker设计

2023-12-01 01:58

本文主要是介绍高级系统架构师必知的经纪人Broker设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是经纪人(Broker)解决方案

每个网络节点的本地Broker 代表系统中的领域对象进行协商并实现进程间通信的功能。远程领域对象的显式接口采用Client Proxy(客户端代理)的方式在其客户端的地址空间实现,并处理所有与Broker 之间的交互。

此外,无论是本地的对象还是远程的,Broker 都为领域对象提供注册其网络位置和所公开的显式接口的功能,并允许它们获取其它所有己注册的领域对象的显式接口。

因此,在分布式系统中,通过使用一系列的Broker,可以从应用的功能中,隔离并封装通信基础设施的细节,这样客户端可以像使用本地服务一样,调用远程服务的方法。


Broker 有两个重要优点:

封装性:使得应用程序开发人员专注于提供必要的领域功能,他们不需要关心底层的网络问题。

位置无关性:允许客户端采用与访问同一地址空间领域对象相同的方式来访问远程领域对象,从而支持计算机网络中的灵活部署。

位置无关性还有利于提升系统的可伸缩性和可用性,因为它可以通过复制和联合领域对象有效地利用网络中可用的集体计算能力。位置无关性对于产品线架构环境来说非常重要,因为不同的产品线实例具有不同的功能性和操作上的需求。


领域对象不要直接处理网络问题


问题:怎样才能够保护仓库管理流程控制系统中的领域对象,使其不必直接处理网络问题并在它们之间提供位置无关的交互机制呢?

对策:利用经纪人(Broker)解决方案,隔离业务和通信基础设施的关系。

解决方案:为网络桥接设计合理的经纪人(Broker),以便分布式的领域时象能互相发现、访问并彼此交流,就像它们部署在一起一样。

这种设计可以帮助我们从应用的功能中,隔离并封装通信基础设施的细节。Broker 系统的封装性和位置无关性,有利于提升系统的可伸缩性和可用性,位置无关性对于产品线系统环境来说非常重要,因为不同的产品线实例具有不同的功能性和操作上的需求。


仓库流程控制系统的网络桥接


如何帮助我们从应用的功能中,隔离并封装通信基础设施的细节,从而保证系统的封装性和位置无关性,有利于提升系统的可伸缩性和可用性呢?通过经纪人(Broker)设计解决方案可以帮助我们解决这类问题。

位置无关性对于产品线系统环境来说非常重要,因为不同的产品线实例具有不同的功能性和操作上的需求。下图描绘了仓库管理流程控制系统的表现层和业务处理层中使用基于Broker 模式的通信基础设施的情况。在该图中,MFC 指的是物流控制(Material Flow Control)。我们假定位于同一层中的领域对象处于同一位置。


为了满足操作大型仓库所需要的性能和吞吐量方面的要求,规定在流程控制系统的Broker 模式中,所有的进程间通信都是异步和面向消息的。调用客户端代理的一个方法会发出一个特定类型的异步消息(请求报文)。远程调用的结果通过“响应报文”异步返回。


然而,纯粹的异步通信机制经常难以理解,更难以在应用服务的实现中正确而有效地使用。


因此客户端代理还要完成以下任务:将异步通信机制封装起来,并向客户端领域对象提供它们所需要的特定通信和调用模型。这种封装有助于应用开发人员以一种更直接、易懂和方便的方式来使用异步通信机制。

这篇关于高级系统架构师必知的经纪人Broker设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/439383

相关文章

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Linux系统之dns域名解析全过程

《Linux系统之dns域名解析全过程》:本文主要介绍Linux系统之dns域名解析全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、dns域名解析介绍1、DNS核心概念1.1 区域 zone1.2 记录 record二、DNS服务的配置1、正向解析的配置

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

kotlin中的行为组件及高级用法

《kotlin中的行为组件及高级用法》Jetpack中的四大行为组件:WorkManager、DataBinding、Coroutines和Lifecycle,分别解决了后台任务调度、数据驱动UI、异... 目录WorkManager工作原理最佳实践Data Binding工作原理进阶技巧Coroutine

Linux系统之authconfig命令的使用解读

《Linux系统之authconfig命令的使用解读》authconfig是一个用于配置Linux系统身份验证和账户管理设置的命令行工具,主要用于RedHat系列的Linux发行版,它提供了一系列选项... 目录linux authconfig命令的使用基本语法常用选项示例总结Linux authconfi

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

CSS3 最强二维布局系统之Grid 网格布局

《CSS3最强二维布局系统之Grid网格布局》CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介... 深入学习 css3 目前最强大的布局系统 Grid 网格布局Grid 网格布局的基本认识Grid 网

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创