MQ关于ActiveMQ的配置文档格式.docx
- 文档编号:12941985
- 上传时间:2022-09-30
- 格式:DOCX
- 页数:10
- 大小:16.37KB
MQ关于ActiveMQ的配置文档格式.docx
《MQ关于ActiveMQ的配置文档格式.docx》由会员分享,可在线阅读,更多相关《MQ关于ActiveMQ的配置文档格式.docx(10页珍藏版)》请在冰豆网上搜索。
如果这两种常用队列都用过的同学,应该来说最大的差异在于:
MSMQ如果要访问远程队列(比如机器A上的程序访问机器B上的队列),会比较恶心。
在数据量比较大的情况之下,一般来说队列服务器会专门的一台或者多台(多台的话,用程序去做热备+负载比较方便,也不需要额外的硬件成本。
简单来说做法可以这样:
消息发送的时候随机向着多台队列服务器上发送消息;
接受的时候开多个线程去分别监听;
热备方面,可以维护一个带状态的队列连接池,如果消息收发失败那么将状态置为不可用,然后起一个线程去定时监测坏的连接是否可用,这个过程一般情况下可以不用加锁,为什么,大家根据各自需要去取舍吧)。
最近搞完了短彩信的网关连接服务,这两种队列我均使用了。
大致的过程是这样的:
上层应用如果要发端彩信,那么将消息直接发送至ActiveMQ(目前用的就是上面说的多台热备+负载,因为实际中下行量非常大5千万条/天以上),然后端彩信网关连接服务部署多套,每套均依赖本机的MSMQ。
为什么呢?
用ActiveMQ的原因是:
上层应用程序和网关连接服务彼此独立,消息需要跨机访问。
用MSMQ的原因是:
ActiveMQ中的数据是一条不分省的大队列,网关连接服务需要按省流控,所以端彩信网关连接服务:
首先把消息从ActiveMQ取出来,然后存至本机上的分省MSMQ,这样做另外的一个好处就是:
ActiveMQ不至于过多挤压,他的数据会分摊到N台短彩信网关连接服务所部署的机器上的MSMQ之中,也就说MSMQ可以起到分摊数据和缓冲的作用。
在之前的随笔中,已经介绍过MSMQ,现在先介绍一下ActiveMQ一些配置,目前好像ActiveMQ配置上的介绍还比较少。
以下是自己总结一些相关资料,贴出来给大家共享
一)问题分析和解决
1)KahaDb和AMQMessageStore两种持久方式如何选择?
官方:
From5.3onwards-werecommendyouuseKahaDB-whichoffersimprovedscalabilityandrecoverabilityovertheAMQMessageStore.
TheAMQMessageStorewhichalthoughfasterthanKahaDB-doesnotscalesaswellasKahaDBandrecoverytimestakelonger.
非官方:
kaha文件系统实际上上是一个文件索引系统,有两部分组成,一个是数据文件系统,由一个个独立的文件组成,缺省文件大小是32M大(可配置),另外一个是索引文件系统,记录消息在数据文件中的位置信息以及数据文件中的空闲块信息。
数据文件是存储到硬盘上的,索引文件是缓存在内存中的。
所以这个存储系统对大消息存储有利,象我们的memberId之类的文本消息,实际上是浪费,索引比消息还大,哈。
我方分析:
推荐:
Amq持久方式
理由:
虽然官方推荐使用KahaDB持久方式,但其提到的优势:
可伸缩性和恢复性较好,对于我们实际的应用意义不大。
从我们自己的使用经验来看,KahaDB持久方式,Data文件是一个大文件(感觉文件过大后,造成队列服务瘫死的可能性会增大),从官网的相关配置(附录1)也找不到哪里可以设置数据的文件的最大Size。
)而Amq持久方式可以设置Data文件最大Size,这样可以保证即时消息积压很多,Data文件也不至于过大。
2)错误:
Channelwasinactivefortoolong
解决方法:
在建立连接的Uri中加入:
wireFormat.maxInactivityDuration=0
参考资源:
Youcandothefollowingtofixtheissues:
1)AppendmaxinactivitydurationtoyourUriintheformatbelow:
2)UsethesameUriattheclientsideaswellasattheserverside
Regards,
如果不这样设置,对应的错误会出现:
2008-05-0709:
22:
56,343[org.apache.activemq.ActiveMQConnection]-[WARN]Asyncexceptionwithnoexceptionlistener:
org.apache.activemq.transport.InactivityIOException:
Channelwasinactivefortoolong:
localhost/127.0.0.1:
61616
org.apache.activemq.transport.InactivityIOException:
ActiveMQ的tcpurl:
tcp:
//localhost:
61616后面要加入?
wireFormat.maxInactivityDuration=0这样的参数,否则当一段时间没有消息发送时会抛出"
Channelwasinactivefortoolong"
异常
3)错误:
Wireformatnegotiationtimeout:
peerdidnotsendhiswireformat.
1)关闭ActiveMqLog4j
打开:
conf/log4j.properties
将:
log4j.rootLogger=INFO,console,logfile
修改为:
log4j.rootLogger=OFF
2)在建立连接的Uri中加入:
maxInactivityDurationInitalDelay=30000
例如北京的测试环境连接Uri:
//192.168.199.80:
61616?
wireFormat.maxInactivityDuration=0&
amp;
maxInactivityDurationInitalDelay=30000&
connection.AsyncSend=true
http:
//activemq.apache.org/javaxjmsjmsexception-wire-format-negociation-timeout-peer-did-not-send-his-wire-format.html
Ifyougetexceptionlikethis,itcanmeanoneofthreethings:
1.You'
reconnectingtotheportnotusedbyActiveMQTCPtransport
Makesuretocheckthatyou'
reconnectingtotheappropriatehost:
port
2.You'
reusinglog4jJMSappenderanddoesn'
tfilteroutActiveMQlogmessages
BesuretoreadHowdoIuselog4jJMSappenderwithActiveMQandmoreimportantlytoneversendActiveMQlogmessagestoJMSappender
3.Yourbrokerisprobablyunderheavyload(ornetworkconnectionisunreliable),soconnectionsetupcannotbecompletedinareasonabletime
Ifyouexperiencesporadicexceptionslikethis,thebestsolutionistousefailovertransport,sothatyourclientscantryconnectingagainifthefirstattemptfails.Ifyou'
regettingthesekindofexceptionsmorefrequentlyyoucanalsotryextendingwireformatnegotiationperiod(default10sec).YoucandothatbyusingwireFormat.maxInactivityDurationInitalDelaypropertyontheconnectionURLinyourclient.
Forexample
wireFormat.maxInactivityDurationInitalDelay=30000
willuse30sectimeout.(貌似有问题!
!
)
4)错误:
Outofmemory
1)设置Java最大内存限制为合适大小:
Bin/activemq.bat中ACTIVEMQ_OPTS=-Xmx512M(默认是512)
2)Activemq.xml配置节:
systemUsage/systemUsage配置大小合适,并且特别注意:
大于所有durabledesitination设置的memoryUsage之和。
备注:
1)尖括号:
“&
gt;
”代表通配符
2)ACTIVEMQ_OPTS的配置〉=memoryUsage中配置〉=所有durabledesitination设置之和
3)SystemUsage配置设置了一些系统内存和硬盘容量,当系统消耗超过这些容量设置时,amq会“slowdownproducer”,还是很重要的。
参考资料:
参考--http:
//activemq.apache.org/javalangoutofmemory.html
对于MQ的内容实用是可管理和可配置的。
首先需要判断的是MQ的哪部分系统因内存不足而导致泄漏,是JVM,broker还是消费者、生产者?
一、内存管理
JVM内存管理:
1.用bin/activemq命令在独立JVM中运行broke
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- MQ 关于 ActiveMQ 配置