JMS 概要
JMS 是 SUN 公司开发的一套访问 MOM(Message-Oriented-Middleware) 消息服务中间件的标准 API
MON 提供消息接收和转发的服务 , 对消息进行缓存和持久操作 , 保证消息的安全性 ,JMS 让开发都无须了解远程过程调用的细节和网络通信协议的细节就可以通过 JMS 向 MOM 发送消息 , 借助消息我们可以松散耦合的方式集成不同的应用
JMS 异步通信
JMS 支持异步消息机制 , 消息生产者发送消息到 MOM, 消息消费者甚至可以不在线 ,MOM 会暂存消息 , 当消息消费者上后 ,MOM 会将消息发给消息消费者 , 消息生产者不必等消息消费者 , 这种异步消息机制在很多系统中是非常重要的
引用 TaskExecuter 实现消息异常传输
JMS 的两种消息类型
PTP (Point to Point) 点对点
Pub/Sub (Publish/Subscribe) 发布 / 订阅
PTP
PTP 生产的消息会放在一个队列中 , 消费者从队列中取走消息 , 消息一旦被取走 , 就会从队列中删除 , 多个观察都观察一个队列 , 但一个消息只能被一个消费都取走
Pub/Sub
用称为主题 (Topic) 的内容分层结构代替了 PTP 模型中的唯一的目的地 , 一个发布者可以将消息发布到某个主题下面 , 订阅了该主题的订阅者就可以收到这个消息 .
JMS 受管理的对象
在 JMS 之前 , 各 MOM 产品都提供了专有的 API 访问其产品 ,JMS 通过 MOM 产品为 Java 程序提供了一个发送消息接受消息的标准 , 便利的方法 , 用 JMS 写的应用可以在任何实现 JMS 标准的 MOM 产品上运行 .
各 MOM 产品实现技术和机制存在很大的差别 , 为保持 JMS 客户端的可移植性 , 实现了 JMS 接口的对象必须与 MOM 产品的专胡技术进行隔离 , 完成这项工作的机制是管理对象 .
这些 JMS 接口的对象由提供者消息系统管理员创建 , 并放置在 JNDI 的空间中 , 然后由 JMS 检索这些对象 , 通过 JMS 接口访问这些对象 ,JMS 提供者必须提供创建管理对象的方法 , 受管对象存放于 JNDI
两个重要的受管对象
ConnectionFacory 用于创建到提供者底层消息系统的连接
Destination 用于指定 JMS 客户端发送消息的目的地或接收消息的来源
JMS 程序只要知道受管对象的 JNDI 名称和 JMS 接口类型就可以了
JMS 的一些重要接口
JMS 定义了一系列的封装消息的高级接口 , 这些接口又分两个消息域
PTP 和 Pub/Sub javax.jms 包下的接口
ConnectionFactory
Connection
Destination
Session 发送消息或接收消息的单线程环境
MessageProducer
MessageConsumer
JMS 的两个版本 JMS1.1 JMS1.02
区别 :JMS1.1 将两种消息统一进行处理 , 透明地操作两种消息域
JMS1.02 区别对待两种消息域 , 针对每种消息域提供了高级接口的子接口
高级接口 PTP 域子接口 Pub/Sub 域子接口
ConnectionFactory QueueConnectionFactory TopicConnectionFactory
Connection QueueConnection TopicConnection
Destination Queue Topic
Session QueueSession TopicSession
MessageProducer QueueSender TopicPublisher
MessageConsumer QueueReceiver QueueBrowser TopicSubscriber
JSM 程序需要基本步骤
1. 通过 JNDI 查找 ConnectionFactory
2. 通过 ConnectionFactory 创建一个 Connection
3. 用 Connection 创建一个或者多个 Session
4. 通过 JNDI 查询一个或多个 Destination
5. 用 Session 和 Destination 创建对应的 MessageProducer 或 MessageConsumer
6. 启动 Conneciton
7. 发送或接收消息
JMS 消息的结构
Header Properties Body 三部分
Header 消息头部
JMSMessageID String
JMSDestination destination
JMSDeliveryMode int 消息持久化设置 Persistent
JMSTimestamp long
JMSExpiration long
JMSPriority int
JMSCorrelationID int
JMSReplyTo String
JMSType Destination 请求程序用它来指定回复消息就发送的地方 , 由
发送消息的 JMS 程序设置
JMSRedelivered String
Message 接口提供了访问 Header 的 API
Properties 消息属性
JMSX 开头的是 JMS 专用的 ,JSM_ 开头的是提供者专用的
Body 消息内容
JMS 有一种消息类型 , 通过五个接口来实现
TextMessage 字符串
ObjectMessage 实现了 Seralizable 接口的对象
MapMessage 是一个 Map
BytesMessage 消息是一个二进制数组
StreamMessage 消息是一组原始数据类型 , 这此数据按标准进行操作 , 按顺序进行填充或读取
消息的收发机制
JMS 事务
JMS 使用 Session 控制事务 , 如何需要事务可以在创建 Session 时标注需要事务
消息确认
消息确认是收到消息发送一个回执确认收到消息
三种确认方式
Session.ATUO_ACKNOWLEDGE 接收到消息自动发送这一个确认
Session.CLIENT_ACKNOWLEDGE 调用 Meeage#acknowledge() 方法 , 显示发送确认
Session.DUPS_OK_ACKNOWLEDGE 延时发送消息 , 但可能有重复接收消息的问题
消息选择 ( 消息过滤 )
选择条件可以通过 Header 和 Properties 进行匹配度设置
MessageConsumer consumer=session.createConsumer(destination,”JMSType=’car’”);
JMSType 和 color weigh 属性
“JMSType=’car’ AND color=’blue’ AND weigh>2500”
JMSCorrelationID=’12312312’ AND phone LIKE ‘12%e3’”;
Phone IS NOT NULL AND age>23
更多参考开心购的交流专区
分享到:
相关推荐
jms学习笔记jms学习笔记jms学习笔记
JMS学习笔记,详解,实例,安装软件精心总结
NULL 博文链接:https://yuxisanren.iteye.com/blog/1912587
JavaEE5学习笔记03-JMS介绍与使用..
JMS教程,学习笔记,基于XML和JMS的异构数据交换集成
NULL 博文链接:https://yingzhuo.iteye.com/blog/1566635
自己辛苦整理的网上的JBoss ESB学习笔记 ,非常详细,代码操作都有截图; 希望大家多支持! 学习笔记PDF的目录如下: 1——搭建ESB开发环境 2 2——第一个ESB代码Hello World 12 3——第二个ESB代码Hello World ...
Java分布式应用学习笔记09JMX-MBean的介绍
Java分布式应用学习笔记08JMX规范与各种监控场景
JPA学习笔记-EJB-06JPA+Spring使用经验。
简单介绍了springdata的知识,包含了springdata 的环境搭建,注解开发等,还有一系列相关的代码供参考。
activeMQ学习笔记,JMS有两种传递消息的方式。标记为NON_PERSISTENT的消息最多投递一次,而标记为PERSISTENT的消息将使用暂存后再转送的机理投递。如果一个JMS服务离线,那么持久性消息不会丢失但是得等到这个服务...
EJB之消息驱动Bean的总结。ejb 消息驱动Bean j2ee jms java
讲解了camel、jms、activeMQ的使用方法,讲解了JBI的原理!
6.2:JMS 172 6.3:Socket 182 6.4:WebService 189 6.5:集群分布式应用(以JBOSS为例) 190 6.6:JNLP原理及应用: 190 6.7:Log4原理及应用: 191 6.8:JFreeChat原理及应用: 191 6.9:几种常用协议 192 7.0:SOA原理 200 8...
现在java家族已经十分强大,每个分支都成为一门学问了,例如web前台开发用的applet,后台要用的servlet;做企业系统,EJB;消息中间件JMS;手机j2me开发手机、数字家电,这也是当初设计java的。
内容: Spring资源管理 Spring表达式语言 定时调度 AOP切面编程-代理功能的加强...Spring与JMS消息组件 Spring与WebService Spring与Redis数据库 JDBC操作模板 Spring事务管理 SpringDataJPA SpringMVC SpringSecurity