activeMQ-15常见activemq问题

activeMQ-15常见activemq问题,第1张

同步发送持久消息能够提供更好的可靠性,但这潜在地影响了程序的相应速度,因为在接受到 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上未处理的消息等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/9795408.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-02
下一篇2023-05-02

发表评论

登录后才能评论

评论列表(0条)

    保存