这是偶在学习过程中记录的,如有错误,请指教
jms提供了应用之间的异步通信机制,异步发送消息时,如下面图1所示,客户端不需要等待服务端处理消息,或者不需要等待消息的投递,客户端发送消息后,继续执行其他程序。相比于同步通信机制,客户端需要等待远程方法完成后,才能继续执行接下来的任务,若远程方法没有给予客户端相关的反馈,那就要泪崩了,客户端就要无线等待服务的反馈,自己也要被阻塞在这知道服务完成。如图2。
图 1、异步通信 图2、同步通信
二、JMS理解
首先我们来说说生活中的例子:我们以邮局为例,我们寄一些快递,一般都是将物品拿到邮局在快递单上写上目的地址及相关信息,然后远方的亲朋好友就收到你的物品了。这个例子和JMS很相似。
JMS有两个重要的概念:消息代理和目的地。
一个消息被发送,首先会将消息发送到消息代理,消息代理就像刚才例子中的邮局,消息代理可以确保消息被送到目的地,同时释放发送者,让其继续其他的业务。
在JMS中有两种类型的目的地:队列和主题。每种类型都与特定的消息模型关联,如:队列的点对点模型和主题的发布/订阅模型。
1、点对点模型
此模型中,每一个消息都有一个发送者和接受者,消息代理得到消息,将消息放到队列中,当接受者接受队列中的消息时,消息从队列中取出投递给接受者,由于消息投递后就会从队列删除,这就保证消息只能投给一个接受者。如下图3
图3 点对点模型
这里投递给一个接受者,不是意味着只能使用一个接受者从队列中获取消息。实际上有多个接受者处理队列的消息,每个接受者处理自己的接受的消息。就像实际中的外卖,很多人中午定了外卖,也有很多的送餐员,队列中有很多外卖订单,接单员时时监视着周围的订单,然后接收订单,最后将外面订单送到客户手里,订单信息
也消失在队列中。
2、发布-订阅模型
发布订阅模型中,消息会发送一个主题,与队列类似,多个接受者都可以监听一个主题。但是与队列不同是,所有的主题订阅者都会接收到此消息。在JMS,发布者不知谁订阅了它的消息。他只知道将消息发送到一个特定的主题,而不知谁监听这个主题。如图4
图4、发布-订阅模式
三、JMS的优点
同步机制理解简单,操作也容易,但是同步机制访问远程服务的客户端会存在一些问题。
· 同步意味着等待,客户端只有等待服务气短结束才能继续执行,若客户端频繁通信会导致服务集聚下降,性能就会下降。
· 客户端服务接口与远程服务耦合,若远程服务接口变化,此时,所有客户端都会做出变化。
· 远程服务不可以,客户端实际也不可用。
· 客户端必须配置网络位置才能与远程服务通信,若网络拓扑结构改变 ,客户端也要调整。
1、无需等待
使用JMS发送消息,客户端不需等待。
2、面向消息和解耦
客户端没有和服务端的任何方法进行绑定。
3、位置独立
4、确保投递
四、ActiveMQ消息代理使用