您当前的位置:首页 > 电脑百科 > 程序开发 > 架构

软件架构设计之构件与中间件技术

时间:2023-04-28 14:20:20  来源:今日头条  作者:IT动力

中间件的定义

其实中间件是属于构件的一种。是一种独立的系统软件或服务程序,可以帮助分布式应用软件在不同技术之间共享资源。

我们把它定性为一类系统软件,比如我们常说的消息中间件,数据库中间件等等都是中间件的一种体现。一般情况都是给应用系统提供服务,而不是直接面向客户。

中间件有哪些特性呢

  • 负责客户机与服务器之间的连接和通信,以及客户机与应用层之间的高效率通信机制。
  • 提供应用层不同服务之间的互操作机制,以及应用层与数据库之间的连接和控制机制。
  • 提供多层架构的应用开发和运行的平台,以及应用开发框架,支持模块化的应用开发。
  • 屏蔽硬件,操作系统,网络和数据库的差异
  • 提供应用的负载均衡和高可用性,安全机制与管理功能,以及交易管理机制,保证交易的一致性。
  • 提供一组通用的服务去执行不同的功能,避免重复的工作, 并且使得应用之间可以相互协作。

中间件有哪些优点呢

  • 面向需求

设计师集中精力于业务逻辑本身

因为你去做的那些对接的工作,就可以交给中间件去实现了,从而让您有更多的时间专注于业务逻辑

比如系统之间远程通信时,使用消息中间件进行中转时,我不用去考虑到底如何通信,底层怎么去走一些逻辑,协议怎么去开发,安全性怎么去保证,都不用我们去管。

  • 业务的分隔与包容性
  • 应用开发人员可以按照不同的业务进行功能的划分,体现为不同的接口或交互服务
  • 设计与实现隔离
  • 构件对外发生作用或构件的交互,都是通过接口进行的,构件使用者只需要知道构件的接口,而不需要关心其内部实现。这就是设计与实现分离的关键。
  • 隔离复杂的系统资源
  • 架构很重要的一个功能就是将系统资源与应用构件隔离,这保证了构件可复用性,甚至是“即插即用”这样的基础,与中间件的意图也是一致的。
  • 符合标准的交互模型
  • 中间件实现了架构的模型,实现标准的协议
  • 软件复用
  • 中间件提供了构件封装,交互规则,与环境的隔离等机制,这些都为软件复用提供了方便的解决方案。
  • 提供对应用构件的管理
  • 基于中间件的的软件可以方便进行管理,因为构件总可以通过标识机制进行划分

Corba(公共对象请求代理体系结构)

Corba是一种远程调用机制,称之为公共对象代理请求的一种机制。这种机制的基本思想如下图所示:

比如我们常常有这种需求,就是整个结构当中有客户端,服务端。有些功能块其实是在服务端实现的,但是客户端要实现这个功能,你直接去调用远程的功能块时,会面临比如说网络问题,调用时怎么具体操作,等等一系列问题。就应运而诞生了中间件技术这样的技术,它在客户端构建起了服务端的一个代理对象,从而调用调用本地代理对象实现调用远程服务端。

代理机制的基本思想是,在客户端会有服务端的对象的引用(也就是一个代理)。假设服务端有一个对象A存在,那么在客户端就有一个对象代理,代理的就是服务端的对象A。有了A的代理到本地,就不用去考虑远程调用问题,直接在本地调用A的代理对象。

并且客户端把请求通过本地的转换机制,然后传递到远程服务端,通过一系列的解析解读之后,连接到服务端这一边来,然后服务端完成执行,再返回回去,最终返回给客户端。

这个跟RMI一样的原理,不错,就是一样的原理。而在Corba中还会涉及到一些对象,这些对象的含义解释如下:

  • 伺服对象(Servant):Corba对象的真正实现,负责完成客户端请求。也就是真正的业务逻辑板块
  • 对象适配器(Object Adapter, POA):用于屏蔽ORB内核的实现细节,为服务器对象的实现者提供抽象接口,以便它们使用ORB内部的某些功能。把请求传递过来,进行接口转换的工作。
  • 对象请求代理(Object Request Broker,ORB): 解释调用并负责查找实现该请求的对象,将参数传给找到的对象,并调用方法返回结果。客户方不需要了解服务对象的位置,通信方式,实现,激活或存储机制。

从另外一个角度来看,中间的ORB的作用是衔接各方,类似于一个总线对象。

  • 对象请求代理(Object Request Broker, ORB)

负责对象在分布环境中透明收发请求和响应,它是构建分布对象应用、在异构或同构环境下实现应用间互操作的基础

  • 对象服务(Obejct Services)
  • 为使用和实现而提供的基本对象集合,这些服务应独立于应用领域
  • 公共设施(Common Facilities)
  • 向终端用户提供一组共享服务接口,例如系统管理,组合文档和电子邮件等
  • 应用接口(Application Interfaces)
  • 由销售商提供的可控制其接口的产品,相应于传统的应用层标识,处于参考模型的最高层。
  • 领域接口(DomAIn Interfaces)
  • 为应用领域服务而提供的接口,如OMG组织为PDM系统定制的规范。

小结

其实我们主要了解的是中间件的概念,以及中间件的思想原理是使用代理对象去访问服务端的对象。像调用本地一样调用远程,也就是我们减少和很多对接的工作,因为中间件帮我们做了。但是学习这件事情,还是得我们亲历亲为,学无止境,继续加油!



Tags:软件架构   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
现代软件架构:事件驱动设计遇上事件溯源
在当今的软件领域中,做出正确的架构决策对于确保性能、可扩展性、可维护性和整体成功至关重要。在众多模式中,事件驱动架构(EDA)和事件溯源(ES)作为复杂软件系统最受欢迎的两种选...【详细内容】
2023-12-13  Search: 软件架构  点击:(111)  评论:(0)  加入收藏
2023软件架构和设计的趋势
2023年即将结束,值得回顾一下过去一年的软件架构和设计流行话题。在本文中,我们将讨论一些常见的软件架构和设计,根据InfoQ的报告,这些架构和设计被广泛采纳。我们主要关注创新...【详细内容】
2023-12-04  Search: 软件架构  点击:(132)  评论:(0)  加入收藏
CSaaS架构:数字孪生软件架构的革命性突破
BS(Browser/Server)和CS(Client/Server)是两种不同的软件架构模式,具有不同的特点和优缺点。BS(Browser/Server)架构BS架构指的是基于浏览器和服务器的软件架构,客户端通常是一个Web...【详细内容】
2023-10-20  Search: 软件架构  点击:(224)  评论:(0)  加入收藏
定义软件架构的四个维度是什么?
软件架构可以从以下四个维度进行定义:1. 结构维度:软件架构包括系统的结构,即系统中各个组件之间的关系和交互方式。这些组件可以是模块、服务、库或其他软件单元。结构维度关...【详细内容】
2023-10-18  Search: 软件架构  点击:(295)  评论:(0)  加入收藏
Linux NFSD软件架构与代码解析
在Linux操作系统发行版有一个NFS服务端,该服务端由内核态的模块和用户态的守护进程构成。其中内核态模块负责数据处理,而用户态守护进程则负责内核态的配置管理等功能。由于核...【详细内容】
2023-08-21  Search: 软件架构  点击:(206)  评论:(0)  加入收藏
三层软件架构导致程序员负担翻倍?
【CSDN 编者按】本文作者从工程师、技术领导者和开发人员角度,在发现自己身陷应用程序“管道”复杂性的困境之中,如何巧妙解决困境!原文链接:https://yrashk.medium.com/repeati...【详细内容】
2023-08-17  Search: 软件架构  点击:(326)  评论:(0)  加入收藏
聊聊【软件架构模式】—微内核架构
概述: 内核模式也被称为插件架构模式。 将附加应用程序功能作为插件添加到核心应用程序,以提供可扩展性以及功能分离和隔离。 这种模式由两种类型的架构组件组成:一个核心系统...【详细内容】
2023-06-20  Search: 软件架构  点击:(292)  评论:(0)  加入收藏
软件架构设计之构件与中间件技术
中间件的定义其实中间件是属于构件的一种。是一种独立的系统软件或服务程序,可以帮助分布式应用软件在不同技术之间共享资源。我们把它定性为一类系统软件,比如我们常说的消息...【详细内容】
2023-04-28  Search: 软件架构  点击:(413)  评论:(0)  加入收藏
软件架构设计之模型驱动架构MDA
概念模型驱动架构MDA, 全称叫做Model Driven Architecture。 Model:表示客观事物的抽象表示 Architecture:表示构成系统的部件,连接件及其约束的规约 Model Driven: 使用模型完...【详细内容】
2023-04-13  Search: 软件架构  点击:(288)  评论:(0)  加入收藏
软件架构设计:B/S层次架构之MVC/MVP/MVVM
层次架构风格从之前的两层C/S到三层C/S,然后演化为三层B/S架构,三层B/S架构之后仍然在往后面演化,我们来看一下层次架构演化过程中都有了哪些演化的架构风格呢?而我们先简单了解...【详细内容】
2023-04-11  Search: 软件架构  点击:(311)  评论:(0)  加入收藏
▌简易百科推荐
对于微服务架构监控应该遵守的原则
随着软件交付方式的变革,微服务架构的兴起使得软件开发变得更加快速和灵活。在这种情况下,监控系统成为了微服务控制系统的核心组成部分。随着软件的复杂性不断增加,了解系统的...【详细内容】
2024-04-03  步步运维步步坑    Tags:架构   点击:(5)  评论:(0)  加入收藏
大模型应用的 10 种架构模式
作者 | 曹洪伟在塑造新领域的过程中,我们往往依赖于一些经过实践验证的策略、方法和模式。这种观念对于软件工程领域的专业人士来说,已经司空见惯,设计模式已成为程序员们的重...【详细内容】
2024-03-27    InfoQ  Tags:架构模式   点击:(13)  评论:(0)  加入收藏
哈啰云原生架构落地实践
一、弹性伸缩技术实践1.全网容器化后一线研发的使用问题全网容器化后一线研发会面临一系列使用问题,包括时机、容量、效率和成本问题,弹性伸缩是云原生容器化后的必然技术选择...【详细内容】
2024-03-27  哈啰技术  微信公众号  Tags:架构   点击:(10)  评论:(0)  加入收藏
DDD 与 CQRS 才是黄金组合
在日常工作中,你是否也遇到过下面几种情况: 使用一个已有接口进行业务开发,上线后出现严重的性能问题,被老板当众质疑:“你为什么不使用缓存接口,这个接口全部走数据库,这怎么能扛...【详细内容】
2024-03-27  dbaplus社群    Tags:DDD   点击:(12)  评论:(0)  加入收藏
高并发架构设计(三大利器:缓存、限流和降级)
软件系统有三个追求:高性能、高并发、高可用,俗称三高。本篇讨论高并发,从高并发是什么到高并发应对的策略、缓存、限流、降级等。引言1.高并发背景互联网行业迅速发展,用户量剧...【详细内容】
2024-03-13    阿里云开发者  Tags:高并发   点击:(6)  评论:(0)  加入收藏
如何判断架构设计的优劣?
架构设计的基本准则是非常重要的,它们指导着我们如何构建可靠、可维护、可测试的系统。下面是这些准则的转换表达方式:简单即美(KISS):KISS原则的核心思想是保持简单。在设计系统...【详细内容】
2024-02-20  二进制跳动  微信公众号  Tags:架构设计   点击:(36)  评论:(0)  加入收藏
详解基于SpringBoot的WebSocket应用开发
在现代Web应用中,实时交互和数据推送的需求日益增长。WebSocket协议作为一种全双工通信协议,允许服务端与客户端之间建立持久性的连接,实现实时、双向的数据传输,极大地提升了用...【详细内容】
2024-01-30  ijunfu  今日头条  Tags:SpringBoot   点击:(16)  评论:(0)  加入收藏
PHP+Go 开发仿简书,实战高并发高可用微服务架构
来百度APP畅享高清图片//下栽のke:chaoxingit.com/2105/PHP和Go语言结合,可以开发出高效且稳定的仿简书应用。在实现高并发和高可用微服务架构时,我们可以采用一些关键技术。首...【详细内容】
2024-01-14  547蓝色星球    Tags:架构   点击:(115)  评论:(0)  加入收藏
GraalVM与Spring Boot 3.0:加速应用性能的完美融合
在2023年,SpringBoot3.0的发布标志着Spring框架对GraalVM的全面支持,这一支持是对Spring技术栈的重要补充。GraalVM是一个高性能的多语言虚拟机,它提供了Ahead-of-Time(AOT)编...【详细内容】
2024-01-11    王建立  Tags:Spring Boot   点击:(124)  评论:(0)  加入收藏
Spring Boot虚拟线程的性能还不如Webflux?
早上看到一篇关于Spring Boot虚拟线程和Webflux性能对比的文章,觉得还不错。内容较长,抓重点给大家介绍一下这篇文章的核心内容,方便大家快速阅读。测试场景作者采用了一个尽可...【详细内容】
2024-01-10  互联网架构小马哥    Tags:Spring Boot   点击:(115)  评论:(0)  加入收藏
站内最新
站内热门
站内头条