`

辨别一些概念

 
阅读更多

关于 微服务,SOA,RPC,RMI,ESB,Web Service,Hessian,Thrift,Rest API的初步理解

 

参考:

SOA和微服务架构的区别?

1.微服务与SOA之间差了一个ESB

2.SOA和微服务架构的区别?

3.用API网关把API管起来

4.谈API网关的背景、架构以及落地方案

5.开发漫谈:千万别说你不了解Docker!

6.CentOS系统下docker的安装配置及使用详解

7.docker和虚拟机VM

对SOA的一点理解

微服务SOA架构与RPC远程过程调用

 

怎样用通俗的语言解释REST,以及RESTful?

 

1.关于RPC(Remote Procedure Call Protocol)

 RPC是指远程过程调用,也就是说两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据

 RPC使用C/S方式,采用http协议,发送请求到服务器,等待服务器返回结果。这个请求包括一个参数集和一个文本集,通常形成“classname.methodname”形式。优点是跨语言跨平台,C端、S端有更大的独立性,缺点是不支持对象,无法在编译器检查错误,只能在运行期检查。

 

2.关于RMI (Remote Method Invocation)

RMI 采用stubs 和 skeletons 来进行远程对象(remote object)的通讯。stub 充当远程对象的客户端代理,有着和远程对象相同的远程接口,远程对象的调用实际是通过调用该对象的客户端代理对象stub来完成的,通过该机制RMI就好比它是本地工作,采用tcp/ip协议,客户端直接调用服务端上的一些方法。优点是强类型,编译期可检查错误,缺点是只能基于Java语言,客户机与服务器紧耦合
注:RPC与RMI

(1)RPC 跨语言,而 RMI只支持Java

(2)RMI 调用远程对象方法,允许方法返回 Java 对象以及基本数据类型,而RPC 不支持对象的概念,传送到 RPC 服务的消息由外部数据表示 (External Data Representation, XDR) 语言表示,这种语言抽象了字节序类和数据类型结构之间的差异。只有由 XDR 定义的数据类型才能被传递, 可以说 RMI 是面向对象方式的 java RPC

(3)在方法调用上,RMI中,远程接口使每个远程方法都具有方法签名。如果一个方法在服务器上执行,但是没有相匹配的签名被添加到这个远程接口上,那么这个新方法就不能被RMI客户方所调用。

在RPC中,当一个请求到达RPC服务器时,这个请求就包含了一个参数集和一个文本值,通常形成“classname.methodname”的形式。这就向RPC服务器表明,被请求的方法在为 “classname”的类中,名叫“methodname”。然后RPC服务器就去搜索与之相匹配的类和方法,并把它作为那种方法参数类型的输入。这里的参数类型是与RPC请求中的类型是匹配的。一旦匹配成功,这个方法就被调用了,其结果被编码后返回客户方。

3.关于JMS(Java Messaging Service)

JMS是Java的消息服务,JMS的客户端之间可以通过JMS服务进行异步的消息传输。JMS支持两种消息模型:Point-to-Point(P2P)和Publish/Subscribe(Pub/Sub),即点对点和发布订阅模型。

 

注:JMS与RMI

采用JMS 服务,对象是在物理上被异步从网络的某个JVM 上直接移动到另一个JVM 上(是消息通知机制)

而RMI 对象是绑定在本地JVM 中,只有函数参数和返回值是通过网络传送的(是请求应答机制)。

 

RMI一般都是同步的,也就是说,当client调用Server的一个方法的时候,需要等到对方的返回,才能继续执行client端,这个过程调用本地方法感觉上是一样的,这也是RMI的一个特点。

JMS 一般只是一个点发出一个Message到Message Server,发出之后一般不会关心谁用了这个message。

所以,一般RMI的应用是紧耦合,JMS的应用相对来说是松散耦合应用。

 

 

 

4.关于 Web Service

Web Service提供的服务是基于web容器的,底层使用http协议,类似一个远程的服务提供者,比如天气预报服务,对各地客户端提供天气预报,是一种请求应答的机制,是跨系统跨平台的。就是通过一个servlet,提供服务出去。

首先客户端从服务器的到WebService的WSDL,同时在客户端声称一个代理类(Proxy Class) 这个代理类负责与WebService

服务器进行Request 和Response 当一个数据(XML格式的)被封装成SOAP格式的数据流发送到服务器端的时候,就会生成一个进程对象并且把接收到这个Request的SOAP包进行解析,然后对事物进行处理,处理结束以后再对这个计算结果进行SOAP

包装,然后把这个包作为一个Response发送给客户端的代理类(Proxy Class),同样地,这个代理类也对这个SOAP包进行解析处理,继而进行后续操作。这就是WebService的一个运行过程。

Web Service大体上分为5个层次:

 1. Http传输信道

 2. XML的数据格式

 3. SOAP封装格式

 4. WSDL的描述方式

 5. UDDI  UDDI是一种目录服务,企业可以使用它对Webservices进行注册和搜索

 

注:Webservice与RMI

 

RMI是在tcp协议上传递可序列化的java对象,只能用在java虚拟机上,绑定语言,客户端和服务端都必须是java

webservice没有这个限制,webservice是在http协议上传递xml文本文件,与语言和平台无关

 

注:Webservice与JMS

Webservice专注于远程服务调用,jms专注于信息交换。

大多数情况下Webservice是两系统间的直接交互(Consumer <--> Producer),而大多数情况下jms是三方系统交互(Consumer <- Broker -> Producer)。当然,JMS也可以实现request-response模式的通信,只要Consumer或Producer其中一方兼任broker即可。

JMS可以做到异步调用完全隔离了客户端和服务提供者,能够抵御流量洪峰; WebService服务通常为同步调用,需要有复杂的对象转换,相比SOAP,现在JSON,rest都是很好的http架构方案;(举一个例子,电子商务的分布式系统中,有支付系统和业务系统,支付系统负责用户付款,在用户在银行付款后需要通知各个业务系统,那么这个时候,既可以用同步也可以用异步,使用异步的好处就能抵御网站暂时的流量高峰,或者能应对慢消费者。)

JMS是java平台上的消息规范。一般jms消息不是一个xml,而是一个java对象,很明显,jms没考虑异构系统,说白了,JMS就没考虑非java的东西。但是好在现在大多数的jms provider(就是JMS的各种实现产品)都解决了异构问题。相比WebService的跨平台各有千秋吧。

 

5.关于SOA

 

 

6.关于微服务

https://www.zhihu.com/question/37808426

https://www.zhihu.com/question/37808426

 

 

微服务跟SOA有什么区别呢?

答案:可以把微服务当做去除了ESB的SOA。ESB是SOA架构中的中心总线,设计图形应该是星形的,而微服务是去中心化的分布式软件架构。

 

 

分享到:
评论

相关推荐

    好看的Windows11概念版鼠标指针

    在描述中提到“非常好看的指针”,这暗示着这些概念指针可能具有更高的分辨率和清晰度,适应了现代高分辨率显示器的需求,提供了更好的视觉体验。此外,它们可能还包含了独特的动画效果,使得用户在操作时有更强的...

    光学仪器分辨本领.pdf

    文档还提供了一些具体的数值例子来说明计算最小分辨角的方法,包括如何根据人眼的参数和观测条件来确定人眼的最小分辨角以及能够分辨物点的最小间距。 从LabVIEW的角度来看,这些光学原理可以被用于开发相应的测量...

    遥感资料(五)+高分辨率卫星遥感应用+高分辨率卫星遥感技术应用趋势、城市规划、基础数据更新、地震灾害救援和重建

    它可以帮助读者了解高分辨率卫星遥感技术的概念和特点,以及其在各个领域的应用前景。 高分辨率遥感技术用于城市规划介绍了高分辨率遥感技术在城市规划中的作用和价值,以及具体的应用案例和方法。 高分辨率遥感...

    初中语文文摘社会卖概念

    【知识点】 1. 概念营销:文章中提到的现象反映了概念营销在市场中的普遍应用...10. 消费教育:提高消费者的辨别能力和消费知识,是避免被概念营销误导的关键,这需要社会、学校和家庭共同参与,培养理性的消费观念。

    以深度学习为基,让概念教学“开花”.pdf

    - 比较分析:引导学生比较不同情境下的概念应用,找出共性和差异,增强概念的辨别力。 - 问题解决:设置实际问题,让学生运用概念解决问题,促使概念与实践相结合。 - 反馈调整:及时对学生的学习进行反馈,指出问题...

    海明码与码距的概念与例子

    因此,若有一个码元是错的,就可以分辨得出,因为奇偶校验将成为奇性。 奇偶校验编码通过增加一位校验位来使编码中 1 个数为奇数(奇校验)或偶数(偶校验),从而使码距变为 2。因为其利用的是编码中 1 的个数的...

    如何分辨数学中易混淆的定义.pdf

    一种方法是列表辨别法,将容易混淆的定义列出表格,明确它们的相同点和不同点,并通过实例加以比较,如倒数和相反数的概念。另一种方法是深入学习数学概念,理解它们的来源、含义、限制条件以及与其他概念的关联。...

    雷达测量精度和分辨力

    本篇文章将深入探讨这两个概念以及影响它们的关键因素。 首先,雷达测量精度是指雷达系统测量单个目标参数(如距离、速度)的准确程度。在实际应用中,雷达系统受到噪声、电波传播条件等多种因素的影响。尤其是在...

    Photoshop基本概念知识

    了解并熟练掌握Photoshop的基本概念对于提升图像编辑能力至关重要。 首先,我们需要理解位图和矢量图的区别。位图是像素化的图像,由无数像素点组成,适合处理照片和复杂图像,但放大时可能会失真。而矢量图则基于...

    基于分辨矩阵的属性约简算法

    在实际应用中,基于分辨矩阵的属性约简算法可以应用于数据预处理、特征选择、概念格构建等多个场景,为后续的数据挖掘任务提供优化的数据基础。 总的来说,"基于分辨矩阵的属性约简算法"是一种有效的数据简化手段,...

    新概念3笔记内容.pdf

    该章节围绕货币伪造和防伪技术展开,介绍了一支专门负责辨别真伪货币的团队——残钞鉴别组。通过这一过程,文章展示了科技在打击犯罪中的应用,同时强调了金融安全和个人财产保护的重要性。 ### Lesson08 A famous ...

    新概念英语第一册L53-54PPT课件.pptx

    2. **方向认知**:课程中讨论了如何辨别`North`(北)、`South`(南)、`West`(西)和`East`(东)四个基本方向。这不仅涉及地理知识,也是语言学习中常见的场景,比如问路或者描述位置。 3. **四季变化**:课件展示了`...

    化学基本概念、基本理论复习策略.doc

    最后,比较是辨别概念异同的有效方法。比如,化学性质与化学变化、氧化反应与化合反应等,通过比较,学生能更清晰地理解概念的内涵和外延,避免混淆。此外,可以通过分类、对称性、本质区别和内在联系等方面进行比较...

    Rossi.zip_图像超分辨_超分辨_超分辨率_超分辨率 matlab_超分辨重建

    在本文中,我们将深入探讨超分辨重建的概念,以及如何利用MATLAB进行超分辨处理。 超分辨重建是一种用于提升图像空间分辨率的技术,它能够从一组低分辨率(LR)图像中恢复出高分辨率(HR)图像。这个过程涉及到图像...

    公共产品公共产品的概念和辨别标准公共产品是学习教案.pptx

    公共产品是经济学中的一个重要概念,它涉及到社会资源的分配与管理。公共产品具有非排他性和非竞争性的特征,这意味着一个人使用该产品并不会排除其他人使用,同时,一个人的消费也不会减少其他人的可用量。比如,...

    频率分辨力的分析

    本文将深入探讨频率分辨力的相关概念,并通过实际案例来说明如何在工程实践中合理选择采样参数,确保信号的真实性和准确性。 #### 二、频率分辨力的基础知识 频率分辨力是指信号处理系统能够区分两个相邻频率的...

    如何分辨数学中易混淆的定义(20211008094654).pdf

    例如,可以采用列表辨别法,将易混淆的概念如倒数和相反数的定义、相同点和不同点列成表格,通过对比加深记忆。此外,数学概念学习法强调理解知识的来源、逐字逐句推敲定义、注意限制条件以及通过对比辨析来深化理解...

    多层多分辨分析算法及在电力系统中的应用

    2. 文献[2]介绍了多小波变换的概念,为多小波函数的构建提供了理论基础。 3. 文献[3]与文献[2]有所不同,侧重于从小波函数的构建角度出发进行研究。 4. 文献[4]提供了小波函数构造的一般方法,为本文提出的新方法...

    基于注意力机制的概念化句嵌入研究.docx

    因此,概念信息增强了句向量的语义辨别力和表达能力。 CSE模型的优势包括: 1) 无需标注数据,自动训练,降低标注和训练成本; 2) 利用词语顺序信息,提高向量表现,同时减少向量维度和存储需求。 本文对相关研究...

Global site tag (gtag.js) - Google Analytics