• RabbitMQ知识点一


    1. RabbitMQ 有哪些重要的组件?

    • ConnectionFactory(连接管理器):应用程序与Rabbit之间建立连接的管理器,程序代码中使用。
    • Channel(信道):消息推送使用的通道。
    • Exchange(交换器):用于接受、分配消息。
    • Queue(队列):用于存储生产者的消息。
    • RoutingKey(路由键):用于把生成者的数据分配到交换器上。
    • BindingKey(绑定键):用于把交换器的消息绑定到队列上。

    2. 要保证消息持久化成功的条件有哪些?

    • 声明队列必须设置持久化 durable 设置为 true.
    • 消息推送投递模式必须设置持久化,deliveryMode 设置为 2(持久)。
    • 消息已经到达持久化交换器。
    • 消息已经到达持久化队列。

    以上四个条件都满足才能保证消息持久化成功。

    3. RabbitMQ 有几种广播类型?

    • direct(默认方式):最基础最简单的模式,发送方把消息发送给订阅方,如果有多个订阅者,默认采取轮询的方式进行消息发送。
    • headers:与 direct 类似,只是性能很差,此类型几乎用不到。
    • fanout:分发模式,把消费分发给所有订阅者。
    • topic:匹配订阅模式,使用正则匹配到消息队列,能匹配到的都能接收到。

    4. RabbitMQ 怎么实现延迟消息队列?

    延迟队列的实现有两种方式:

    • 通过消息过期后进入死信交换器,再由交换器转发到延迟消费队列,实现延迟功能;
    • 使用 RabbitMQ-delayed-message-exchange 插件实现延迟功能。

    5. RabbitMQ 集群中唯一一个磁盘节点崩溃了会发生什么情况?

    如果唯一磁盘的磁盘节点崩溃了,不能进行以下操作:

    • 不能创建队列
    • 不能创建交换器
    • 不能创建绑定
    • 不能添加用户
    • 不能更改权限
    • 不能添加和删除集群节点

    唯一磁盘节点崩溃了,集群是可以保持运行的,但你不能更改任何东西。

  • 相关阅读:
    工作经验和学历孰优孰劣
    关于c语言文件的基本操作1
    从头学起Expert C Program 1
    栈和堆——c语言中
    浅谈进程和线程的区别
    通用试题库组卷策略算法
    marquee标记用法及在asp.net中的应用(来自于网上)
    在ASP.NET页面中显示自动生成图片的两种方法
    《ASP.NET高级编程》电子版下载地址
    从中央气象台抓取天气预报
  • 原文地址:https://www.cnblogs.com/heqiyoujing/p/12152961.html
Copyright © 2020-2023  润新知