RabbitMQ系列-6.如何通过控制台创建交换机、队列、死信队列、延迟队列

概述

在实际生产环境中,我们更推荐使用RabbitMQ后台管理页面创建交换机、队列、声明绑定关系、配置死信队列、延迟队列等
今天带大家看看如何在RabbitMQ后台管理页面操作这些东西

登录管理后台

创建队列

点击Exchange页签

填写你要创建的交换机参数,注意选择正确的Virtual host

在参数下方可以点击,给你的交换机声明备份交换机(关于备份交换机请看前面文章)

创建完成后效果如下:

创建队列

点击Queues页签

上图中涂红的部分我们可以指定队列参数
例如:

创建后效果:

交换机与队列绑定

对交换机和队列进行绑定可以在Exchanges中声明,也可以在Queues中声明

下面以Queues中声明为例:
点击列表中队列的名字,就会进入队列详情页面

在这个队列详情页面,我们可以指定交换机与队列的绑定关系:

因为我声明的是扇形交换机类型,所以我就不写路由key了
点击【Bind】按钮,即可绑定成功

绑定成功后效果:

重复上述步骤,我们建立如下3个交换机和3个队列:

总结一下:

  • kc-guideorder-exchange是我们的业务要用的交换机(fanout类型),与队列kc-guideorder-queue绑定,并且队列kc-guideorder-queue我们设置了消息过期时间600s,消息过期后会成为死信,将会进入我们在队列声明时指定的死信队列:kc-deadletter-exchange
  • kc-deadletter-exchange同样设计为fanout类型,它与队列kc-deadletter-queue绑定,所以上面的死信最终会被存储到队列kc-deadletter-queue上
  • 同时kc-guideorder-exchange我们为它指定了一个备份交换机kc-guideorder-queue-ae,发送到交换机kc-guideorder-exchange失败的信息会被转发到这个备份交换机上,备份交换机为与kc-guideorder-queue-ae这个队列绑定,所以消息最终会存储在队列kc-guideorder-queue-ae上

测试

1.延迟队列测试

我们往kc-guideorder-exchange这个交换机发送一条消息

@RestController
public class SendDelayMessageController {

    @Autowired
    RabbitSender rabbitSender;

    @GetMapping("/sendDelayMessageAck")
    public String sendDirectMessage() {
        rabbitSender.convertAndSend("kc-guideorder-exchange", null, "Hell,我是延迟消息");
        return "ok";
    }
}

在对应的队列中发现存在此消息

等待10分钟.....

消费端监听器代码:

@RabbitListener(queues = "kc-deadletter-queue")
public void onMessage(Message message, Channel channel) throws IOException {
    System.out.println("接收到消息总体内容:" + message);
    System.out.println("实际消息内容:" + new String(message.getBody()));

    // TODO 业务逻辑
    // 1.获取message中的body,解析消息内容
    // 2.其他业务逻辑......

    // 回执情形1:消费成功
    channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);

    // 回执情形2:消费成功消费处理失败,重新放入队列(一定要慎用,防止造成无限返回队列->消费者->返回队列.....造成消息积压)
    // channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, true);

    // 回执情形3:消费处理失败,拒绝接收(可以指定是否重新放入队列,如果消息不重新放入队列,RabbitMQ服务端会将消息移除)
    // channel.basicReject(message.getMessageProperties().getDeliveryTag(), false);
}

控制台输出

接收到消息总体内容:(Body:'"Hell,我是延迟消息"' MessageProperties [headers={spring_listener_return_correlation=ed70bfd9-a258-4a3b-ba14-f95e2635223e, spring_returned_message_correlation=20201215122141164475429, x-first-death-exchange=kc-guideorder-exchange, x-death=[{reason=expired, count=1, exchange=kc-guideorder-exchange, time=Tue Dec 15 12:31:41 CST 2020, routing-keys=[], queue=kc-guideorder-queue}], x-first-death-reason=expired, x-first-death-queue=kc-guideorder-queue, __TypeId__=java.lang.String}, contentType=application/json, contentEncoding=UTF-8, contentLength=0, receivedDeliveryMode=PERSISTENT, priority=0, redelivered=false, receivedExchange=kc-deadletter-exchange, receivedRoutingKey=, deliveryTag=1, consumerTag=amq.ctag-1lY9szRg4nFzYEvxFG-AHQ, consumerQueue=kc-deadletter-queue])
实际消息内容:"Hell,我是延迟消息"

2.备份交换机测试

为了测试备份交换机是否生效,我们先把kc-guideorder-exchange与队列kc-guideorder-queue进行解绑,这样发送到kc-guideorder-exchange的消息是找不到对应的队列的,测试其是否能为我们将消息转发到备份交换机上

我们再发送一条消息

然后查看备份交换机队列:

发现此队列已经存在一条消息

实际生产环境,我们可以消费此队列做通知、或者其他补偿措施

你可能感兴趣的:(RabbitMQ系列-6.如何通过控制台创建交换机、队列、死信队列、延迟队列)