1 JMS
1.1 JMS的基本构件
1.1.1 连接工厂
连接工厂是客户用来创建连接的对象,例如ActiveMQ提供的ActiveMQConnectionFactory。
1.1.2 连接
JMS Connection封装了客户与JMS提供者之间的一个虚拟的连接。
1.1.3 会话
JMS Session是生产和消费消息的一个单线程上下文。会话用于创建消息生产者(producer)、消息消费者(consumer)和消息(message)等。会话提供了一个事务性的上下文,在这个上下文中,一组发送和接收被组合到了一个原子操作中。
1.1.4 目的地
目的地是客户用来指定它生产的消息的目标和它消费的消息的来源的对象。JMS1.0.2规范中定义了两种消息传递域:点对点(PTP)消息传递域和发布/订阅消息传递域。
点对点消息传递域的特点如下:
每个消息只能有一个消费者。
消息的生产者和消费者之间没有时间上的相关性。无论消费者在生产者发送消息的时候是否处于运行状态,它都可以提取消息。
发布/订阅消息传递域的特点如下:
每个消息可以有多个消费者。
生产者和消费者之间有时间上的相关性。订阅一个主题的消费者只能消费自它订阅之后发布的消息。JMS规范允许客户创建持久订阅,这在一定程度上放松了时间上的相关性要求。持久订阅允许消费者消费它在未处于激活状态时发送的消息。
在点对点消息传递域中,目的地被成为队列(queue);在发布/订阅消息传递域中,目的地被成为主题(topic)。
1.1.5 消息生产者
消息生产者是由会话创建的一个对象,用于把消息发送到一个目的地。
1.1.6 消息消费者
消息消费者是由会话创建的一个对象,它用于接收发送到目的地的消息。消息的消费可以采用以下两种方法之一:
同步消费。通过调用消费者的receive方法从目的地中显式提取消息。receive方法可以一直阻塞到消息到达。
异步消费。客户可以为消费者注册一个消息监听器,以定义在消息到达时所采取的动作。
1.1.7 消息
JMS消息由以下三部分组成:
消息头。每个消息头字段都有相应的getter和setter方法。
消息属性。如果需要除消息头字段以外的值,那么可以使用消息属性。
消息体。JMS定义的消息类型有TextMessage、MapMessage、BytesMessage、StreamMessage和ObjectMessage。
1.2 JMS的可靠性机制
1.2.1 确认
JMS消息只有在被确认之后,才认为已经被成功地消费了。消息的成功消费通常包含三个阶段:客户接收消息、客户处理消息和消息被确认。
在事务性会话中,当一个事务被提交的时候,确认自动发生。在非事务性会话中,消息何时被确认取决于创建会话时的应答模式(acknowledgement mode)。该参数有以下三个可选值:
Session.AUTO_ACKNOWLEDGE。当客户成功的从receive方法返回的时候,或者从MessageListener.onMessage方法成功返回的时候,会话自动确认客户收到的消息。
Session.CLIENT_ACKNOWLEDGE。客户通过消息的acknowledge方法确认消息。需要注意的是,在这种模式中,确认是在会话层上进行:确认一个被消费的消息将自动确认所有已被会话消费的消息。例如,如果一个消息消费者消费了10个消息,然后确认第5个消息,那么所有10个消息都被确认。
Session.DUPS_ACKNOWLEDGE。该选择只是会话迟钝第确认消息的提交。如果JMS provider失败,那么可能会导致一些重复的消息。如果是重复的消息,那么JMS provider必须把消息头的JMSRedelivered字段设置为true。
1.2.2 持久性
JMS 支持以下两种消息提交模式:
PERSISTENT。指示JMS provider持久保存消息,以保证消息不会因为JMS provider的失败而丢失。
NON_PERSISTENT。不要求JMS provider持久保存消息。
1.2.3 优先级
可以使用消息优先级来指示JMS provider首先提交紧急的消息。优先级分10个级别,从0(最低)到9(最高)。如果不指定优先级,默认级别是4。需要注意的是,JMS provider并不一定保证按照优先级的顺序提交消息。
1.2.4 消息过期
可以设置消息在一定时间后过期,默认是永不过期。
1.2.5 临时目的地
可以通过会话上的createTemporaryQueue方法和createTemporaryTopic方法来创建临时目的地。它们的存在时间只限于创建它们的连接所保持的时间。只有创建该临时目的地的连接上的消息消费者才能够从临时目的地中提取消息。
1.2.6 持久订阅
首先消息生产者必须使用PERSISTENT提交消息。客户可以通过会话上的createDurableSubscriber方法来创建一个持久订阅,该方法的第一个参数必须是一个topic。第二个参数是订阅的名称。
JMS provider会存储发布到持久订阅对应的topic上的消息。如果最初创建持久订阅的客户或者任何其它客户使用相同的连接工厂和连接的客户ID、相同的主题和相同的订阅名再次调用会话上的createDurableSubscriber方法,那么该持久订阅就会被激活。JMS provider会象客户发送客户处于非激活状态时所发布的消息。
持久订阅在某个时刻只能有一个激活的订阅者。持久订阅在创建之后会一直保留,直到应用程序调用会话上的unsubscribe方法。
1.2.7 本地事务
在一个JMS客户端,可以使用本地事务来组合消息的发送和接收。JMS Session接口提供了commit和rollback方法。事务提交意味着生产的所有消息被发送,消费的所有消息被确认;事务回滚意味着生产的所有消息被销毁,消费的所有消息被恢复并重新提交,除非它们已经过期。
事务性的会话总是牵涉到事务处理中,commit或rollback方法一旦被调用,一个事务就结束了,而另一个事务被开始。关闭事务性会话将回滚其中的事务。
需要注意的是,如果使用请求/回复机制,即发送一个消息,同时希望在同一个事务中等待接收该消息的回复,那么程序将被挂起,因为知道事务提交,发送操作才会真正执行。
需要注意的还有一个,消息的生产和消费不能包含在同一个事务中。
分享到:
相关推荐
JMS 及消息队列概要介绍 JMS 是 Java 平台上的一种消息服务规范,允许 Java 应用程序创建、发送、接收和读取消息。JMS 提供了两种类型的消息模型:点对点模型和发布/订阅模型。点对点模型中,生产者将消息发送到...
- **资源连接**:配置数据源、JMS队列和主题,以连接到后端数据库和其他消息系统。 - **安全策略**:设置SSL通信、角色权限、访问控制列表,确保应用的安全性。 总的来说,创建WebSphere应用程序服务器(概要文件)...
回到 JMS 模块的资源概要,点击 "新建",选择创建 "队列"。在新页面中,设定队列的名称和 JNDI 名称,例如 "gt3.esb.jms.mdb.BaseQueueAsynMDBean"。接着,选择刚刚创建的子部署,以关联队列与子部署。 接下来是...
9. jmsActivationSpec – 配置JMS(Java消息服务)激活规范,用于定义如何接收消息。 10. jpa – 指定JPA(Java持久层API)相关的配置信息。 11. keyStore – 配置密钥存储,用于管理证书,支持SSL/TLS通信。 12....
Jmeter最初设计目的是测试JServ(Tomcat的前身),但随着时间的推移,它的功能得到了扩展,现在能够覆盖多种协议的测试,包括FTP、HTTP、RPC、JUnit、JMS、LDAP、WebService(Soap)、Request、Mail以及JDBC数据库压力...
它最初设计用于测试Tomcat服务器的JServ,但现在已经扩展到了各种测试场景,包括FTP、HTTP、RPC、JUNIT、JMS、LDAP、WebService(Soap)、Mail和JDBC等。JMeter能够进行衰退测试,通过创建包含断言的脚本来验证应用...
### Jemeter学习概要详解 #### Jemeter概述 Jemeter是一款完全基于Java的开源性能测试工具,由Apache基金会开发与维护。最初设计目的是评估JServ(Tomcat的前身)的性能,随后发展成为功能全面的性能测试平台,...
### jmeter学习概要 #### 一、JMeter概述 **Apache JMeter** 是一款完全由 Java 开发的开源工具,主要用于压力测试和性能测试。它最初被设计出来是为了评估 Tomcat 的前身 JServ 的执行效率,随着项目的成熟和发展...
OSB概要介绍 OSB的核心功能包括: - **服务代理(Proxy Services)**:作为外部系统访问内部服务的接口,隐藏实际服务的细节。 - **业务服务(Business Services)**:表示实际执行操作的服务,可以是Web服务、...
首先,阐述了章节的内容概要、介绍以及设定的前提条件。接着,详细说明了一个基础问题的轮廓,即创建一个简单的解决方案。物理环境部分描述了CAPS运行所需的硬件和软件环境。预设工作包括安装和配置CAPS,以及创建...
创建概要文件后,你可以进一步配置WAS,包括设置服务器、安全管理、数据源、JMS队列和话题等。 此外,IHS(IBM HTTP Server)通常用于负载均衡和请求分发,而Plugin则是连接HTTP服务器和WAS的关键组件。如果需要这...
- **配置JMS**:在集群作用域上配置Java消息服务(JMS)资源。 - **配置DataSource**:在集群作用域上配置数据源资源。 #### 六、总结 通过上述步骤,可以成功在WAS 6环境中配置一个基本的集群,并部署应用程序。...
部署过程包括选择部署类型(如EAR、WAR、JAR等),配置服务器端的资源,如数据源、JMS 队列等。 6. **WebSphere Application Server 概念**: - **单元 (Cell)**: 最高级别的管理实体,可以包含多个节点,用于跨多...
内容概要:该文档介绍了常见的三种Java应用服务器(JBoss, Tomcat, Jetty)的整体架构及其启动流程,并深入探讨了它们各自的特性与配置要点。此外,文中还详细阐述了应用服务器的关键组件如类加载器(ClassLoader)的...
它提供了一组标准和服务,包括Servlet、JSP(JavaServer Pages)、EJB(Enterprise JavaBeans)、JMS(Java Message Service)等,用于处理Web请求、业务逻辑和数据持久化。 2. **Servlet**:Servlet是Java Web开发...
JMS 程序的最终目的是生产和消费的消息能被其他程序使用,JMS 的 Message 是一个既简单又不乏灵活性的基本格式,允许创建不同平台上符合非JMS 程序格式的消息。 Message 由消息头,属性和消息体三部份组成。 Active ...
•核心特性: SpringApplication |外部配置|概要|日志 •Web应用:MVC |嵌入式容器 •处理数据:SQL | NO-SQL •消息传递:概述| JMS •测试:概述|引导应用| Utils •扩展:自动配置| @Conditions •管理端点:概述 •连接...