ActiveMQ的学习(四)(消息投递方式+死信队列+重发策略)

消息投递方式

 

投递方式一共有三种:异步投递,延迟投递,定时投递。

异步投递

同步发送:消息生产者使用持久(Persistent)传递模式发送信息的时候,Producer.send()方法会被阻塞,直到broker发送一个确认消息给生产者(ProducerAck),这个确认消息按时broker已经成功接收到消息并把消息保存到二级存储中。

异步发送:如果应用程序能够容忍一些消息的丢失,那么可以使用异步发送。异步发送不会在受到broker的确认之前一直阻塞Producer.send方法。

如果想要使用异步,在brokerURL中增加jms.alwaysSyncSend=false&jms.useAsyncSend=true属性

1. 如果设置了alwaysSyncSend=true系统将会忽略useAsyncSend设置的值都采用同步。

2. 当alwaysSyncSend=false时,“NON_PERSISTENT”(非持久化),事务中的消息将使用“异步发送”

3. 当alwaysSyncSend=false时,如果指定了useAsyncSend=true,“PERSISTENT”类型的消息使用异步发送。如果useAsyncSend=false,“PERSISTENT”类型的消息使用同步发送。

总结:默认情况(alwaysSyncSend=false,useAsyncSend=false),非持久化消息,事务内的消息均采用异步发送;对于持久化消息采用同步发送。

异步投递如何确认发送成功:

异步投递丢失消息的场景是:生产者设置UserAsyncSend=true,使用producer.send(msg)持续发送消息。

由于消息不阻塞,生产者会认为所有send的消息均被成功发送至MQ。如果MQ突然宕机,此时生产者端内存中尚未被发送至MQ的消息都会丢失。

这时,可以给异步投递方法接收回调,以确认消息是否发送成功。

延迟投递

生产者提供两个发送消息的方法,一个是即时发送消息,一个是延时发送消息。

延迟投递和定时投递的四个属性

首先修改activemq.xml文件里的属性,添加schedulerSupport=“true”配置

1 <broker xmlns="http://activemq.apache.org/schema/core"  brokerName="localhost" dataDirectory="${activemq. data}" schedulerSupport="true" />

之后在代码里设置延时时长

1 message.setLongProperty(ScheduledMessage.AMO_SCHEDULED_DELAY, 10000);//10秒

定时投递

启动类上添加

业务上添加

 

 

死信队列

 

死信队列,用来保存处理失败或者过期的信息。

出现以下情况的时候,消息会被重发:

A transacted session is used and rollback() is called.

A transacted session is closed before commit is called.

A session is using CLIENT_ACKNOWLEDGE and Session.recover() is called.

当一个消息被重发超过6次(缺省为6),会给broker发送一个“poison ack”,这个消息被认为是a poison pill,这时broker会将这个消息发送到死信队列,以便后续处理。

注意两点:

1. 缺省持久消息过期,会被送到DLQ,非持久消息不会送到DLQ。

2. 缺省的死信队列是ActiveMQ.DLQ,如果没有特别指定,死信都会被发送到这个队列中。

可以通过配置文件activemq.xml来调整死信发送策略。

为每个队列建立独立得死信队列(下面是queue和topic两种形式,选一种即可)

效果:

还有其他策略,这个要根据实际情况来对应处理。

比如:

非持久消息保存到死信队列

1 <policyEntry queue=">">
2     <deadLetterStrategy>
3         <sharedDeadLetterStrategy processNonPersistent="true" />
4     </deadLetterStrategy>
5 </policyEntry>    

过期消息不保存到死信队列

1 <policyEntry queue=">">
2     <deadLetterStrategy>
3         <sharedDeadLetterStrategy processExpired="false" />
4     </deadLetterStrategy>
5 </policyEntry>

 

 

重发策略

 

RedeliveryPolicy重发策略设置

 

 

 

 

 

 

参考:

1. https://www.cnblogs.com/rainwang/p/5146223.html

2. 黑马程序员得mq教程

 

持续更新!!!

 

posted @ 2020-02-17 08:47  夏夜凉凉  阅读(1323)  评论(1编辑  收藏  举报