JMS入门(三)点对点消息传送模型示例
2013-12-09 23:54
281 查看
一、点对点模型
当你只需要将消息发送给唯一的一个消费者时,就应该使用点对点模型,并且这是个高可靠的模型。我们用一个贷款示例来演示这种模型
QBorrower 类将贷款申请发送给 RequestQueue 队列,并且使用 ReplyQueue 队列从 QLender 类中接收结果
QLender 要根据 QBorrower 提供的工资和贷款额来确定是否给予贷款,若贷款额低于200000,则最多可贷款4倍于工资的金额,若贷款额大于200000,则最多可贷款10/3 倍工资的贷款额:
MapMessage msg = (MapMessage) message; double salary = msg.getDouble("Salary"); double loanAmt = msg.getDouble("LoanAmount"); // 决定是否接收或拒绝贷款申请 if (loanAmt < 200000) { accepted = (salary / loanAmt) > .25; } else { accepted = (salary / loanAmt) > .33; }
二、模型示例
我已经准备好了示例和编译、运行脚本,你只需要启动 ActiveMQ,然后依次运行 compile.bat,runQBorrower.bat 和 runQLender.bat 即可启动后结果如下:
下面我们在 QBorrower 中输入工资和贷款额:
看到 QLender 接受了第一次申请,拒绝了第二次申请
三、使用多个接收者实现负载均衡
即使有多个消费者在队列中侦听同一消息,也只有一个消费者线程会接收到消息,JMS提供者会使用负载均衡在消费者中均匀发布消息,再运行一次runQLender.bat 来添加一个侦听者,可以看到 JMS提供者通过负载均衡来分发消息:
点对点模型示例
相关文章推荐
- JMS消息服务器(二)——点对点消息传送模型
- JMS消息服务器(二)——点对点消息传送模型
- 消息中间件JMS点对点入门小Demo
- 【原创】JMS两种消息模型(点对点,发布订阅)的注意细节
- ActiveMQ 点对点消息传送模型
- JMS订阅/发布消息传送模型
- Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送
- 基于Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送
- 基于Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送
- 点对点消息传送模型
- 点对点消息传送模型
- JMS消息类型模型(点对点,发布/订阅)
- 基于Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送
- 基于Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送
- 基于Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送
- JMS发布/订阅消息传送例子
- JMS消息类型模型[queue和topic的区别]
- 消息中间件JMS入门
- JMS消息服务入门讲解,基于ActiveMQ的实现【基础篇】
- Spring整合JMS点对点入门小Demo