• Rabbit MQ总结


    135、Rabbit MQ的使用场景有哪些?

    1) 抢购活动,削峰填谷,防止系统崩溃。

    2) 延迟信息处理,比如10分钟之后给下单未付款的用户发送邮件提醒

    3) 解耦系统,对于新增的功能可以单独写模块扩展,比如用户确认评价之后,新增了给用户返回积分的功能,这个时候不用业务代码里添加新的增加积分功能,只需要把新增积分的接口订阅确认评价的消息队列即可,后边再添加任何功能只需要订阅对应的消息队列即可。

    136、Rabbit MQ有哪些重要的角色?

    1) 生产者: 消息的创建者,负责创建和推送数据到消息服务器。

    2) 消费者:消息的接收方,用于处理数据和确认消息

    3) 代理: 就是RabbitMQ本身,用于扮演“快递”的角色,本身不生产消息,只是扮演“快递”的角色。

    137、RabbitMQ有哪些重要的组件?

    ConnectionFactory(连接管理器): 应用程序和rabbit直接建立的管理权,程序中代码使用

    Channel(信道): 消息推送使用的通道。

    Exchange(交换器): 用于接受、分配消息

    Queue(队列): 用于存储生产者的消息

    RoutingKey(路由键): 用于把生成者的数据分配到交互器。

    BindingKey(绑定键): 用于把交换器的消息绑定到队列上。

    138、Rabbit MQ 中的vhost作用是什么?

    vhost: 每个Rabbit MQ都能创建很多vhost,我们称之为虚拟主机,每个虚拟主机其实都是mini版的RabbitMQ,它拥有自己的队列,交互器和绑定,拥有自己的权限机制。

    139、Rabbit MQ的消息是怎么发送的?

    首页客户端必须连接到RabbitMQ服务器才能发布和消费消息,客户端和Rabbit Server之间会创建一个tcp连接,一旦tcp打开并通过了认证(认证就是你发送rabbit的用户名和密码),你的客户端和Rabbit MQ就创建了一套amqp信道(channel),信道是创建在“真实”tcp上的虚拟连接,amqp命令都是通过信道发送出去的,每个信道都会有一个唯一的id,不论是发布消息,订阅队列都是通过这个信道完成的。

    140、RabbitMQ 怎么保证消息的稳定性?

    提供了事务的功能

    通过将channel设置为confirm(确认)模式

    141. Rabbit MQ怎么避免消息丢失?

    把消息持久化磁盘,保证服务器重启消息不丢失。

    每个集群中至少有一个物理磁盘,保证消息落入磁盘。

    143、Rabbit MQ持久化有什么缺点?

    持久化的缺点就是降低服务器的吞吐量,因为使用的是磁盘而非内存存储,从而降低了吞吐量。可尽量使用ssd硬盘来缓存吞吐量的问题。

    144. RabbitMQ有几种广播类型?

    direct(默认方式): 最基础最简单的模式,发送方把消息发送给订阅者,如果有多个订阅者,默认采取轮询的方式进行消息发送

    headers: 与direct类似,只是性能很差,此类型几乎用不到。

    fanout: 分发模式,把消费分发给所有订阅者。

    topic: 匹配订阅模式,使用正则匹配消息队列,能匹配到都能接收到。

    145、RabbitMQ怎么实现延迟消息队列

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

    1) 通过消息过期后进入交换器,再由交换器发到延迟消息队列,实现延迟功能。

    2) 使用RabbitMQ-delayed-message-exchage插件实现延迟功能。

    146、RabbitMQ集群有什么用?

    1) 高可用: 某个服务出现问题,整个RabbitMQ还可以继续使用;

    2) 高容量: 集群可以承载更多的消息量。

    147. RabbitMQ节点的类型有哪些?

    磁盘节点: 消息会存储到磁盘。

    内存节点: 消息都存储在内存中,重启服务器消息丢失,性能高于磁盘类型。

    148、RabbitMQ集群搭建需要注意哪些问题?

    1) 各节点之间使用“-link”连接,此属性不能忽略。

    2) 各节点使用的erlang cookie值必须相同,此值相当于“秘钥”的公共,用于各节点的认证

    3)整个集群必须包含一个磁盘节点。

    149、RabbitMQ每个节点是其他节点的完整拷贝吗? 为什么?

    不是,原因有以下两个:

    存储空间的考虑:如果每个节点都拥有所有队列的完全拷贝,这样新增节点不但没有新增存储空间,返回增加了更多的冗余数据

    性能考虑:如果每条消息都需要完整拷贝到每一个集群节点,那新增节点并没有提升处理消息的能力,最多是保持和单节点相同的性能甚至更糟。

    150、Rabbit集群中唯一一个磁盘崩溃了会发生什么情况?

    不能进行以下操作

    1)  不能创建队列

    2) 不能创建交换器

    3) 不能创建绑定

    4) 不能添加用户

    5) 不能更改权限

    6) 不能添加和创建集群节点

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

    151、RabbitMQ对集群节点的停止顺序有要求吗?

    RabbitMQ对集群的停止的顺序是有要求的,应该先关闭内存节点,最后再关闭磁盘节点。如果顺序恰好相反的话,可能会造成消息的丢失。

    152、其它

    https://blog.csdn.net/jerryDzan/article/details/89183625

  • 相关阅读:
    数据访问之注册审核(重点是审核!!!)常用于企业、公司、医院等网站---2017-05-04
    5个简约的网站---2017-05-03
    数据访问(租房子多条件查询)---2017-05-03
    数据访问之 批量删除 ---2017-05-03
    数据访问之查询数据 ---2017--05-02
    php部分--数组(包含指针思想遍历数组);
    php部分---面向对象静态、抽象类、oop接口、加载类、魔术方法、关键字。
    PHP部分---字符串处理(文中例子不断更新);
    php部分--面向对象三大特性-封装(另加连续调用的一个例子)、继承(重写、重载的例子)、多态;
    php部分---面向对象:定义、实例化、构造函数、析构函数;
  • 原文地址:https://www.cnblogs.com/linlf03/p/10778420.html
Copyright © 2020-2023  润新知