菜鸟刷面试题(二、RabbitMQ篇)

目录:

  • rabbitmq 的使用场景有哪些?
  • rabbitmq 有哪些重要的角色?
  • rabbitmq 有哪些重要的组件?
  • rabbitmq 中 vhost 的作用是什么?
  • rabbitmq 的消息是怎么发送的?
  • rabbitmq 怎么保证消息的稳定性?
  • rabbitmq 怎么避免消息丢失?
  • 要保证消息持久化成功的条件有哪些?
  • rabbitmq 持久化有什么缺点?
  • rabbitmq 有几种广播类型?
  • rabbitmq 怎么实现延迟消息队列?
  • rabbitmq 集群有什么用?
  • rabbitmq 节点的类型有哪些?
  • rabbitmq 集群搭建需要注意哪些问题?
  • rabbitmq 每个节点是其他节点的完整拷贝吗?为什么?
  • rabbitmq 集群中唯一一个磁盘节点崩溃了会发生什么情况?
  • rabbitmq 对集群节点停止顺序有要求吗?

rabbitmq 的使用场景有哪些?

1、异步调用

2、应用解耦

3、流量削峰

4、数据冗余

5、延迟队列

6、分布式事务

......

rabbitmq 有哪些重要的角色?

1、生产者:发送消息的角色。

2、消费者:接收并处理消息的角色。

3、消息代理者:传递消息的角色,本身不产生和消费消息。

rabbitmq 有哪些重要的组件?

1、生产、消费者

2、消息、信道

3、交换器、路由键、队列、broker

rabbitmq 中 vhost 的作用是什么?

vhost可以看作是小型的RabbitMQ服务器,他拥有自己独立的交换器、队列、绑定关系、以及权限管理

客户端连接RabbitMQ时必须制定一个vhost,默认使用"/"

也就是说一个RabbitMQ服务可以拥有很多个子RabbitMQ服务,这些字RabbitMQ服务可以为其它很多应用程序提供服务;这样可以减少RabbitMQ服务器搭建的成本

rabbitmq 的消息是怎么发送的?

生产者通过信道将消息发送到交换器,然后交换器再根据路由键将消息路由到对应的队列中。

rabbitmq 怎么保证消息的稳定性?

对于发送方来说,可以使用事务或更轻量级别的发送方确认机制来保证消息达到RabbitMQ服务器。

对于接收方来说,autoAck设置成false,在处理完消息后再手动确认

rabbitmq 怎么避免消息丢失?

1、队列的durable设为true,将消息持久化到磁盘。

2、采用消费者确认模式。

3、对RabbitMQ集群,通过镜像队列备份数据。

4、可以将requeue设置为true,将漏处理的消息重新入队。

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

1、队列必须为持久化的

2、消息的投递模式必须是持久化的,deliveryMode=2

3、消息已到达持久化的交换器和队列

rabbitmq 持久化有什么缺点?

持久化会多一次IO操作,在一定程度上会降低RabbitMQ的吞吐量,如果不计服务器成本的话可以考虑使用固态硬盘(SSD)来优化

rabbitmq 有几种广播类型?

fanout、direct、topic。

rabbitmq 怎么实现延迟消息队列?

采用死信交换器,也有些人叫做死信队列,在创建队列时指定x-message-ttl、x-dead-letter-exchange这两个参数来实现(利用消息过期会进入死信队列的特性)。

rabbitmq 集群有什么用?

1、不仅可以线性扩展RabbitMQ的吞吐量。

2、还可以使用镜像队列来降低消息丢失的风险。

3、以及某台服务器出现问题后RabbitMQ还能正常的提供服务。

rabbitmq 节点的类型有哪些?

磁盘节点和内存节点:

1、磁盘节点主要用于持久化交换器、队列及用户角色权限等

2、内存节点主要用于读写RabbitMQ消息,但消息都存储在内存中,服务器重启则消息丢失;但其性能高于磁盘节点。

rabbitmq 集群搭建需要注意哪些问题?

1、保证各个节点的cookie一致,否则节点之间无法通信。

2、必须存在一个磁盘节点,高可用的话最好一个以上

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

不是;集群节点不对其它节点的队列进行复制,只会存储队列所在节点及元数据

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

虽然还能够正常的读写消息,但无法创建交换器、队列、绑定关系以及用户和用户的权限角色等

rabbitmq 对集群节点停止顺序有要求吗?

停止服务:应当先关闭内存节点,再关闭磁盘节点。先关闭磁盘节点的话会导致无法创建交换器、队列、绑定关系,从而可能会导致数据丢失。

启动服务:先启动磁盘节点,再启动内存节点。

原文地址:https://www.cnblogs.com/bzfsdr/p/12041579.html

时间: 2024-10-12 03:36:05

菜鸟刷面试题(二、RabbitMQ篇)的相关文章

菜鸟刷面试题(三、Redis篇)

目录: redis是什么?都有哪些使用场景? redis有哪些功能? redis和memecache有什么区别? redis为什么是单线程的? 什么是缓存穿透?怎么解决? redis支持的数据类型有哪些? redis支持的java客户端都有哪些? jedis和 redisson 有哪些区别? 怎么保证缓存和数据库数据的一致性? redis持久化有几种方式? redis怎么实现分布式锁? redis分布式锁有什么缺陷? redis如何做内存优化? redis淘汰策略有哪些? redis常见的性能问

菜鸟刷面试题(五、Java容器篇)

目录: java 容器都有哪些? Collection 和 Collections 有什么区别? List.Set.Map 之间的区别是什么? HashMap 和 Hashtable 有什么区别? 如何决定使用 HashMap 还是 TreeMap? 说一下 HashMap 的实现原理? 说一下 HashSet 的实现原理? ArrayList 和 LinkedList 的区别是什么? 如何实现数组和 List 之间的转换? ArrayList 和 Vector 的区别是什么? Array 和

【每日3分钟技术干货 | 面试题+答案 | MyBatis篇(一)】

1. MyBatis 中 #{}和 ${}的区别是什么? #{}是预编译处理,${}是字符替换.在使用 #{}时,MyBatis 会将 SQL 中的 #{}替换成"?",配合 PreparedStatement 的 set 方法赋值,这样可以有效的防止 SQL 注入,保证程序的运行安全. 2. MyBatis 有几种分页方式? 分页方式:逻辑分页和物理分页. 逻辑分页:使用 MyBatis 自带的 RowBounds 进行分页,它是一次性查询很多数据,然后在数据中再进行检索. 物理分页

【每日3分钟技术干货 | 面试题+答案 | Zookeeper篇(一)】

1. zookeeper 是什么? zookeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 google chubby 的开源实现,是 hadoop 和 hbase 的重要组件.它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护.域名服务.分布式同步.组服务等. 2. zookeeper 都有哪些功能? 集群管理:监控节点存活状态.运行请求等. 主节点选举:主节点挂掉了之后可以从备用的节点开始新一轮选主,主节点选举说的就是这个选举的过程,使用 zookeeper

【每日3分钟技术干货 | 面试题+答案 | SpringCloud篇(一)】

1. 什么是 spring cloud? spring cloud 是一系列框架的有序集合.它利用 spring boot 的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册.配置中心.消息总线.负载均衡.断路器.数据监控等,都可以用 spring boot 的开发风格做到一键启动和部署. 2. spring cloud 断路器的作用是什么? 在分布式架构中,断路器模式的作用也是类似的,当某个服务单元发生故障(类似用电器发生短路)之后,通过断路器的故障监控(类似熔断保险丝),向调用

【每日3分钟技术干货 | 面试题+答案 |多线程篇(一)】

1.为什么要使用线程池 避免频繁地创建和销毁线程,达到线程对象的重用.另外,使用线程池还可以根据项目灵活地控制并发的数目. 2.java中如何获取到线程dump文件 死循环.死锁.阻塞.页面打开慢等问题,打线程dump是最好的解决问题的途径.所谓线程dump也就是线程堆栈,获取到线程堆栈有两步: 1)获取到线程的pid,可以通过使用jps命令,在Linux环境下还可以使用ps -ef | grep java 2)打印线程堆栈,可以通过使用jstack pid命令,在Linux环境下还可以使用ki

菜鸟系列之C/C++经典试题(二)

求子数组的最大和 题目描述: 输入一个整形数组,数组里有正数也有负数.数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.求所有子数组的和的最大值.要求时间复杂度为O(n). 例如输入的数组为1, -2, 3, 10, -4, 7, 2, -5,和最大的子数组为3, 10, -4,7, 2,因此输出为该子数组的和18. 这个问题在各大公司面试中出现频率之频繁,被人引用次数之多,非一般面试题可与之匹敌.ok,下面,咱们来一步一步分析这个题. 分析与解法 解法一 求一个数组的最大子数组和

【转】BAT及各大互联网公司2014前端笔试面试题:JavaScript篇

原文转自:http://blog.jobbole.com/78738/ 很多面试题是我自己面试BAT亲身经历碰到的.整理分享出来希望更多的前端er共同进步吧,不仅适用于求职者,对于巩固复习前端基础更是大有裨益. 而更多的题目是我一路以来收集的,也有往年的,答案不确保一定正确,如有错误或有更好的解法,还请斧正. 前面几题是会很基础,越下越有深度. 附上第二篇:BAT及各大互联网公司2014前端笔试面试题–Html,Css篇 前面几题是会很基础,越下越有深度. 初级Javascript: 1.Jav

菜鸟学Java(二十一)——如何更好的进行单元测试——JUnit

测试在软件声明周期中的重要性,不用我多说想必大家也都非常清楚.软件测试有很多分类,从测试的方法上可分为:黑盒测试.白盒测试.静态测试.动态测试等:从软件开发的过程分为:单元测试.集成测试.确认测试.验收.回归等. 在众多的分类中,与开发人员关系最紧密的莫过于单元测试了.像其他种类的测试基本上都是由专门的测试人员来完成,只有单元测试是完全由开发人员来完成的.那么今天我们就来说说什么是单元测试,为什么要进行单元测试,以及如更好的何进行单元测试. 什么是单元测试? 单元测试(unit testing)