JMS学习及相关理解


这是偶在学习过程中记录的,如有错误,请指教吐舌头吐舌头吐舌头


一、JMS简介

 

 jms提供了应用之间的异步通信机制,异步发送消息时,如下面图1所示,客户端不需要等待服务端处理消息,或者不需要等待消息的投递,客户端发送消息后,继续执行其他程序。相比于同步通信机制,客户端需要等待远程方法完成后,才能继续执行接下来的任务,若远程方法没有给予客户端相关的反馈,那就要泪崩了,客户端就要无线等待服务的反馈,自己也要被阻塞在这知道服务完成。如图2。

 

                                     

                   图 1、异步通信                                                                                                                                   图2、同步通信

 

 

二、JMS理解

 

首先我们来说说生活中的例子:我们以邮局为例,我们寄一些快递,一般都是将物品拿到邮局在快递单上写上目的地址及相关信息,然后远方的亲朋好友就收到你的物品了。这个例子和JMS很相似。

 JMS有两个重要的概念:消息代理目的地。

一个消息被发送,首先会将消息发送到消息代理,消息代理就像刚才例子中的邮局,消息代理可以确保消息被送到目的地,同时释放发送者,让其继续其他的业务。

JMS中有两种类型的目的地:队列和主题。每种类型都与特定的消息模型关联,如:队列的点对点模型主题的发布/订阅模型

 

 1、点对点模型

     此模型中,每一个消息都有一个发送者和接受者,消息代理得到消息,将消息放到队列中,当接受者接受队列中的消息时,消息从队列中取出投递给接受者,由于消息投递后就会从队列删除,这就保证消息只能投给一个接受者。如下图3

 

                                   

                                                                                                                图3 点对点模型

           这里投递给一个接受者,不是意味着只能使用一个接受者从队列中获取消息。实际上有多个接受者处理队列的消息,每个接受者处理自己的接受的消息。就像实际中的外卖,很多人中午定了外卖,也有很多的送餐员,队列中有很多外卖订单,接单员时时监视着周围的订单,然后接收订单,最后将外面订单送到客户手里,订单信息                                                                             

也消失在队列中。

 

2、发布-订阅模型

 

发布订阅模型中,消息会发送一个主题,与队列类似,多个接受者都可以监听一个主题。但是与队列不同是,所有的主题订阅者都会接收到此消息。在JMS,发布者不知谁订阅了它的消息。他只知道将消息发送到一个特定的主题,而不知谁监听这个主题。如图4

 

                                             

                                                                                                    图4、发布-订阅模式

 

 

三、JMS的优点

 

同步机制理解简单,操作也容易,但是同步机制访问远程服务的客户端会存在一些问题。

· 同步意味着等待,客户端只有等待服务气短结束才能继续执行,若客户端频繁通信会导致服务集聚下降,性能就会下降。

· 客户端服务接口与远程服务耦合,若远程服务接口变化,此时,所有客户端都会做出变化。

· 远程服务不可以,客户端实际也不可用。

· 客户端必须配置网络位置才能与远程服务通信,若网络拓扑结构改变 ,客户端也要调整。

1、无需等待

使用JMS发送消息,客户端不需等待。

2、面向消息和解耦

客户端没有和服务端的任何方法进行绑定。

3、位置独立

4、确保投递

   

四、ActiveMQ消息代理使用

 


 


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值