《JMS简明教程(PDF格式)》第21章


TopicPublisher MessageProducer
TopicSubscriber MessageConsumer
6。2 Pub/Sub 延时
由于在所有的Pub/Sub 系统中通常都会有一些延时,订阅者实际看见的消息的时间根据 
JMS 提供商产生新的订阅者和提供商在转发过程中保留消息的时间长度会有很大的不同。
例如,由于新的订阅者传播到整个系统会花费一些时间,因此来自远方发布者的消息可 
能会被错过。当创建新的订阅者时,它可以接收在创建之间发送的消息,因为提供商可能还 
没有让订阅者可以获取这些消息。
45 / 66
…………………………………………………………Page 46……………………………………………………………
JMS 没有定义在pub/sub 提供商调整到新的客户端的间隔期内的语义。JMS 语义只应用 
到达到“稳定状态”的提供商。
6。3 永久订阅
非永久订阅维持着订阅者对象的生命。这意味着客户端将只能看见在订阅者是活动时发 
布到主题的消息。如果订阅者是不活动的,那么它将错过发布到主题的消息。
订阅者可以以高负荷的成本来使用永久订阅。永久订阅者用一个唯一标识向 JMS 注册 
一个永久订阅。使用同一个标识的后续订阅者对象重新使用前一个订阅者使用过的订阅,这 
个订阅的状态是前一个订阅者留下的。如果永久订阅没有活动的订阅者,则 JMS 保留订阅 
的消息直到它们被订阅接收或到期。
所有的JMS 提高商必须能够动态创建和删除永久订阅的JMS 应用。另外,某些JMS 提 
供商可以提供管理配置永久订阅的工具。如果永久订阅已经被配置,它可以默默覆盖由客户 
端指定的订阅。
不活动的永久订阅是一个存在但当前还没有消息消费者向它订阅的永久订阅。
6。4 主题(Topic )管理
某些产品要求主题是静态定义、要与权限控制相关联,等等;其他的甚至没有主题管理 
的概念。
JMS 没有定义创建、管理或删除主题的工具。
一种特殊类型的主题是TemporaryTopic ,它用于创建一个对于TopicConnection 来说是唯 
一的Topic 。参见节6。6 “临时主题(TemporaryTopic )”了解详细信息。
6。5 Topic
Topic 对象封装了提供商特有的主题名。它用于在JMS 方法中指定主题标识。
许多Pub/Sub 提供商将主题组织成层级形式,并提供很多选项来订阅层级的部分主题。 
JMS 对Topic 对象代表什么没有限制。它可能是主题层级的叶子,或者可能是层级的较大部 
分(用于订阅信息的大类)。
主题的组织和订阅授权都是Pub/Sub 应用架构很重要的部分。JMS 没有指定如何实现它 
们的策略。如果应用使用了提供上特有的分组机制,那么它应当记录它。如果应用使用不同 
的提供商,那么管理员负责构造相等的主题架构和创建相等的Topic 对象。
6。6 TemporaryTopic
TemporaryTopic 是一个唯一的Topic 对象,它为Connection 或TopicConnection 永久化而 
创建。它是系统定义的Topic ,只能被创建它的Connection 或TopicConnection 消费。
根据定义,向一个临时主题创建永久订阅是没有意义的。如果这么做就是程序错误,它 
可能会也可能不会被JMS 提供商检测到。
参见节4。4。3 “创建临时目的地”了解详细信息。
46 / 66
…………………………………………………………Page 47……………………………………………………………
6。7 TopicConnectionFactory
客户端使用TopicConnectionFactory 来创建带JMS Pub/Sub 提供商的TopicConnection 。
参见节4。2 “受管理对象”了解JMS ConnectionFactory 对象的更多信息。
6。8 TopicConnection
TopicConnection 是一个连接到 JMS Pub/Sub 提供商的活动连接。客户端使用 
TopicConnection 来创建一到多个用于生产和消费消息的TopicSession 。
参见节4。3 “Connection ”了解更多信息。
6。9 TopicSession
TopicSession 提供了创建TopicPublisher 、TopicSubscriber 和TemporaryTopic 的方法。它 
也提供了用于删除客户端永久订阅的unsubscribe 方法。
如果已经接收到消息但消息在TopicSession 终止时还没有被确认,则永久TopicSubscriber 
必须保留和重发这些消息;非永久订阅不需要这么做。
参见节4。4 “Session ”了解更多信息。
6。10 TopicPublisher
客户端使用TopicPublisher 向一个topic 发布消息。TopicPublisher 是JMS MessageProducer 
的 Pub/Sub 变量。可以使用 MessageProducer 想一个 Topic 发送消息。参见节 4。6 
“MessageProducer”了解公共特性的描述。
6。11 TopicSubscriber
客户端使用 TopicSubscriber 来接收已发布到主题的消息。TopicSubscriber 是 JMS
MessageConsumer 的Pub/Sub 变量。参见节4。5 “MessageConsumer”了解更多信息。
普通的TopicSubscriber 不是永久性的。它们只接收它们是活动时被发布的消息。
被订阅者的消息选择器过滤掉的消息永远不会被订阅者接收到。从订阅者的角度来看, 
这些消息是不存在的。
在某些情况下,连接可以既是到主题的发布又是到主题的订阅。订阅者的NoLocal 属性 
可以让订阅者抑制转发由它自己的连接发布的消息。
TopicSession 可以为每个目的地创建多个TopicSubscriber ,它将目的地的每个消息都转发 
到符合接收条件的TopicSubscriber 。这些都工作在消息的复制品上,而不互相影响;确认一 
个消息不会确认其他的消息;一个消息可能被立刻转发,但另一个可能等待消费者处理完它 
前面的消息。
47 / 66
…………………………………………………………Page 48……………………………………………………………
6。11。1 永久TopicSubscriber
如果客户端需要接收发布到主题上的所有消息,包括订阅者是不活动时发布的消息,那 
么它使用永久TopicSubscriber 。永久TopicSubscriber 可以由Session 或TopicSession 创建。JMS 
保留永久订阅的记录并保证来自Topic 的发布者的所有消息都被保留,直到这些消息被永久 
订阅者确认或它们到期。
使用永久订阅的会话必须总是提供同一个客户端标识。另外,每个客户端必须指定唯一 
标识(在客户端标识符中)它创建的每个永久订阅的名字。一次只能有一个会话可以有一个 
特殊永久订阅的TopicSubscriber 。参见节4。3。2 “客户端标识”了解更多信息。
客户端可以通过创建一个具有相同名字和新主题和/或消息选择器或 NoLocal 属性的永 
久TopicSubscriber 来改变一个存在的永久订阅。改变一个永久订阅相当于删除并重新创建它。
Session 和TopicSession 提供了unsubsribe 用于删除它们客户端创建的永久订阅。这回删 
除由提供商代表订阅者维护的状态。对客户端来说,当永久订阅有活动的 TopicSubscriber 
或者当被接收到的消息是当前事务的一部分或者还没有在会话中确认时,删除一个永久订阅 
是错误?
小说推荐
返回首页返回目录