博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ActiveMQ 中的消息游标(Message cursors)
阅读量:4031 次
发布时间:2019-05-24

本文共 2058 字,大约阅读时间需要 6 分钟。

  在Activemq以前的版本中,broker会把待发送的消息保存在内存中。这种方式的缺陷是当消费者消费的速度赶不上生产者的速度时,会在broker的内存中积攒大量的消息,当达到一个限额后,broker就不再接收消息。这时生产者就被阻塞了,直到broker将内存清理能保存消息后才能继续发送。
   在5.0版本后,Activemq实现了一种新的内存模型来防止慢消费者阻塞快速生产者。通常消息在未发生或者发送后未收到消费者的确认信息时都会持久保存消息到存储中。当有消费者来可以消费消息时,broker会批量从存储中取出消息,发送给消费者。游标就是指向下次批量获取消息时的存储位置。
根据游标的保存方式不同,可分为三种:
Store-based cursors
broker默认采用的游标。它将游标信息保存在存储中。针对速度不同的消费者,这种游标机制采取的方式不同。对于快速消费者,因为消费速度很快,存储中的消息数量会很少,所以不需要游标。这时,消息发送到broker时,先保存在持久存储中,然后直接发送给了消费者。而对于慢消费者,消息的持久存储中会保存大量的消息,所以需要使用游标来指定下一次批量读取消息的位置。
VM cursors
若消费者能跟上生产者生产的速度,这时持久存储中消息虽然不是很多,但是若能也能在内存中保存一些游标,对获取存储中的消息的性能会有很大的提升。
File-based cursors
对VM cursors 的一种改进。当内存中的游标达到一定限额后,就会将一些游标存储到临时文件中。
Activemq默认使用store-based游标。当然也可为不同的Destination修改游标策略。通过修改destinationPolicy节点来更改默认配置。destinationPolicy节点包含多ge policyMap节点。policyMap包含一个policyEntries节点,policyEntries节点包含多个policyEntry 节点。policyEntry 就是具体的一个游标策略了。Topics的消费者分为持久订阅者和临时订阅者,所以有两套配置。Queues只有一类消费者,所以只有一套配置。对于持久订阅者可以使用PendingDurableSubscriberMessageStoragePolicy来指定游标策略。可配置的策略有vmDurableCursor和fileDurableSubscriberCursor.
对于临时订阅者可以使用pendingSubscriberPolicy 来指定。可配置的策略有vmCursor和fileCursor。下面是关于Topics的一些xml配置:
Xml代码
  1. <beans ... >  
  2.   <broker ...>  
  3.     ...   
  4.     <destinationPolicy>  
  5.       <policyMap>  
  6.         <policyEntries>  
  7.           <policyEntry topic="com.iona.>">  
  8.             ...   
  9.             <pendingSubscriberPolicy>  
  10.               <vmCursor />  
  11.             </pendingSubscriberPolicy>  
  12.             <PendingDurableSubscriberMessageStoragePolicy>  
  13.               <fileDurableSubscriberPolicy />  
  14.             </PendingDurableSubscriberMessageStoragePolicy>  
  15.             ...   
  16.           </policyEntry>  
  17.           ...   
  18.         </policyEntries>  
  19.       </policyMap>  
  20.     </destinationPolicy>  
  21.     ...   
  22.   </broker>  
  23.   ...   
  24. </beans>  
Queues 同样也有vm和file两种类型的游标存储策略。pendingQueuePolicy 节点的可配置子节点有vmQueueCursor和fileQueueCursor
Xml代码
  1. <beans ... >  
  2.   <broker ...>  
  3.     ...   
  4.     <destinationPolicy>  
  5.       <policyMap>  
  6.         <policyEntries>  
  7.           <policyEntry queue="com.iona.>">  
  8.             ...   
  9.             <pendingQueuePolicy>  
  10.               <vmQueueCursor />  
  11.             </pendingQueuePolicy>  
  12.             ...   
  13.           </policyEntry>  
  14.           ...   
  15.         </policyEntries>  
  16.       </policyMap>  
  17.     </destinationPolicy>  
  18.     ...   
  19.   </broker>  
  20.   ...   
  21. </beans>  

转载地址:http://onebi.baihongyu.com/

你可能感兴趣的文章
RNN-LSTM-GRU
查看>>
文本处理——词向量
查看>>
编码器—解码器(seq2seq)+ Attention
查看>>
深度学习在搜索广告查询词关键字匹配中的应用
查看>>
关于智能运维(AIOps)的学与思
查看>>
关于问答系统(Q&A)、对话系统(Chatbot)的学与思
查看>>
关于信息检索(IR)、搜索引擎的学与思
查看>>
关于广告、推荐中的CTR的学于思
查看>>
文本分类
查看>>
自然语言处理中的Attention机制
查看>>
pbc 的使用
查看>>
luasocket 安装遇到的问题
查看>>
lua读写redis的环境部署
查看>>
Using MIT-Scheme in MacOS X on the Command Line
查看>>
php redis 接口说明
查看>>
cocos2dx使用lua和protobuf
查看>>
lua5.2 可能会遇到的一些错误
查看>>
C语言编译过程
查看>>
stirling formula prove
查看>>
关于数字类型转化为整型的方法
查看>>