一 设置消息的ttl两种方式:
a.统一设置队列中消息的过期时间;b.设置指定消息的过期时间
--同时设置时,以小的那个为准
二 统一设置队列中消息的过期时间
a.参数
Map< String , Object > args = new HashMap<String , Object>();
args.put("x-message-ttl " , 6000);
channel.queueDeclare(queueName , durable , exclusive , autoDelete , args) ;
b.Policy
c.http api
三 设置消息的过期时间
a.channel.basicPublish(EXCHAGE_NAME, ROUTING_KEY, new AMQP.BasicProperties().builder()
.expiration("10000")//毫秒,超过时间从队列删除
.build()
, msg2.getBytes());
b.Policy
c.http api
四 两种的差别
设置队列的过期时间,则消息到过期时间后会从队列删除
设置消息的过期时间,会在消息投递给消费者的时候判断,是否过期,过期则删除
五 设置消息的ttl特殊情况说明
不设置,则表示永不过期
设置为0,则表示,如果不可以立刻被消费,则删除(可与死信队列结合实现immediate的功能)
六 设置队列的TTL
队列的ttl用于在规则时间后,删除队列;
规则:队列没有任何消费者,没有被重新声明,过期时间段内没有调用过basic.get
定义ttl时间
Map< String , Object > args = new HashMap<String , Object>();
args.put("x-expires" , 18000);
channel.queueDeclare(queueName , durable , exclusive , autoDelete , args) ;