这里写目录标题
- 第一种是声明队列的时候,在队列的属性中设置,这样该队列中的消息都会有相同的有效期;
-第二种是发送消息时给消息设置属性,可以为每条消息都设置不同的TTL。
如果两种方式都设置了,则以设置的较小的为准。
TTL是:Time To Live的缩写 , 也就是生存时间
RabbitMQ支持消息的过期时间,在消息发送时可以进行指定
RabbitMQ支持为每个队列设置消息的超时时间,从消息入队列开始计算只要超过了队列的超时时间的配置,那么消息会自动的清除
一:TTL队列过期时间设置
第一步配置好自己的yml
spring:
rabbitmq:
host: 192.168.192.168
port: 5672
virtual-host: /
username: guest
password: guest
创建生产者
@Component
public class TtlProducer {
@Autowired
private RabbitTemplate rabbitTemplate;
public void makeTTL(String a,String b,int c){
String Exchange = "TTLExchange";
String TTL = "ttl";
String message = UUID.randomUUID().toString();
System.out.println("消息来了~~~~~"+message);
//参数一:交换机, 参数二:key, 参数三:消息
rabbitTemplate.convertAndSend(Exchange,TTL,message);
}
}
创建消费者
@Configuration
public class TtlConsumer {
@Bean//注册一个direct模式的交换机
public DirectExchange directExchange(){
return new DirectExchange("TTLExchange",true,false);
}
@Bean
public Queue aaa(){
HashMap<String, Object> args = new HashMap<>();
//我们可以给这个队列设置一个时间
args.put("x-message-ttl",5000);//表示5秒
return new Queue("TTLQueue01.queue",true,false,false,args);
}
@Bean
public Binding aaaBinding(){
return BindingBuilder.bind(aaa()).to(directExchange()).with("ttl");
}
}
运行
我们可以去web界面看
等5s后