
同步发送持久消息能够提供更好的可靠性,但这潜在地影响了程序的相应速度,因为在接受到 broker 的确认消息之前应用程序或线程会被阻塞。如果应用程序能够容忍一些消息的丢失,那么可以使用异步发送。异步发送不会在受到 broker 的确认之前一直阻塞 Producersend 方法。
解决办法:
1)添加事务
2)设置异步参数
[1]设置ConnectionFactory时指定使用异步
[2]不在构造函数中指定,而是修改ConnectionFactory的配置
[3]在实例化后的ActiveMQConnection对象中设置异步发送
异步发送的弊端
1)异步发送丢失消息的场景是:生产者设置UseAsyncSend=true,使用producersend(msg)持续发送消息。由于消息不阻塞,生产者会认为所有send的消息均被成功发送至MQ。如果服务端突然宕机,此时生产者端内存中尚未被发送至MQ的消息都会丢失。
此时,需要在发送时设置回调函数,从而知道消息是否发送成功:
目前比较多的解决方案有几个:
一、结合MQ消息中间件实现的可靠消息最终一致性
二、TCC补偿性事务解决方案
三、最大努力通知型方案
第一种方案:可靠消息最终一致性,需要业务系统结合MQ消息中间件实现,在实现过程中需要保证消息的成功发送及成功消费。即需要通过业务系统控制MQ的消息状态
第二种方案:TCC补偿性,分为三个阶段TRYING-CONFIRMING-CANCELING。每个阶段做不同的处理。
TRYING阶段主要是对业务系统进行检测及资源预留
CONFIRMING阶段是做业务提交,通过TRYING阶段执行成功后,再执行该阶段。默认如果TRYING阶段执行成功,CONFIRMING就一定能成功。
CANCELING阶段是回对业务做回滚,在TRYING阶段中,如果存在分支事务TRYING失败,则需要调用CANCELING将已预留的资源进行释放。
第三种方案:最大努力通知xing型,这种方案主要用在与第三方系统通讯时,比如:调用微信或支付宝支付后的支付结果通知。这种方案也是结合MQ进行实现,例如:通过MQ发送>
func尝担佰杆脂访拌诗饱涧tion executeScript(html) { var reg = ww //对整段木屑颗粒机HTML片段按拆分 var htmlBlock = htmlsplit(""); for ( var i in htmlBlock) { var blocks; if (blocks = htmlBlock[i]match(reg)) { var code = blocks[1]
以上就是关于activeMQ-15常见activemq问题全部的内容,包括:activeMQ-15常见activemq问题、ActiveMQ有人用过没_activemq使用教程、activemq 怎么用编程方式得到 queue上未处理的消息等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)