摘要:\u003C\u002Fp\u003E\u003Cp\u003E如果你依然觉得有些茫然,那么以下的福利很适合你,有自己个人学习规划的可以忽略,但是期待提升自己技术栈的也可以看看(\u003Cstrong\u003E文末彩蛋\u003C\u002Fstrong\u003E)\u003C\u002Fp\u003E\u003Cdiv class=\"pgc-img\"\u003E\u003Cimg src=\"http:\u002F\u002Fp1.pstatp.com\u002Flarge\u002Fdfic-imagehandler\u002Fef24cf52-441c-4838-acc7-6be76e2f9c17\" img_width=\"1200\" img_height=\"801\" alt=\"前P8程序员留下来面试题干货:关于RabbitMQ「含答案」\" inline=\"0\"\u003E\u003Cp class=\"pgc-img-caption\"\u003E\u003C\u002Fp\u003E\u003C\u002Fdiv\u003E\u003Ch1\u003E\u003Cstrong\u003E一:rabbitmq 的使用场景有哪些。\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003E\u003Cstrong\u003E关于RabbitMq还有一些剖析,已经整理成文档资料,由于篇幅限制就没有全部展现出来,截图如下所示:\u003C\u002Fstrong\u003E\u003C\u002Fp\u003E\u003Cdiv class=\"pgc-img\"\u003E\u003Cimg src=\"http:\u002F\u002Fp1.pstatp.com\u002Flarge\u002Fpgc-image\u002F8c00db6c6d1242f99063f1eeac419a36\" img_width=\"1843\" img_height=\"874\" alt=\"前P8程序员留下来面试题干货:关于RabbitMQ「含答案」\" inline=\"0\"\u003E\u003Cp class=\"pgc-img-caption\"\u003E\u003C\u002Fp\u003E\u003C\u002Fdiv\u003E\u003Cp\u003E还有更多如\u003Cstrong\u003EZookeeper 、Kafka 、MongoDB 、Hbase 等由于平台机制原因,需要这份耗费大量精力,\u003C\u002Fstrong\u003E花费大量时间整理出来的\u003Cstrong\u003EJava核心知识笔记,\u003C\u002Fstrong\u003E欢迎关注笔者\u003Cstrong\u003E,转发后后台私信回复【笔记】\u003C\u002Fstrong\u003E来获取领取方式。

"\u003Cdiv\u003E\u003Cp\u003E为什么我会一直执念于要去BAT之类的大型互联网公司工作?除了因为薪水诱人,更是因为能有大规模分布式的技术可以挑战。\u003C\u002Fp\u003E\u003Cp\u003E始终保持你的学习欲。对于工程师来说,学习永无止境。但埋头苦学是不够的,你要注意自己的学习一定要有系统性,除了手头的项目和身边“大牛”的指导外,看书和网络课程是最有效的方法,用少量的金钱换取宝贵的时间,是非常值得的。\u003C\u002Fp\u003E\u003Cp\u003E如果你依然觉得有些茫然,那么以下的福利很适合你,有自己个人学习规划的可以忽略,但是期待提升自己技术栈的也可以看看(\u003Cstrong\u003E文末彩蛋\u003C\u002Fstrong\u003E)\u003C\u002Fp\u003E\u003Cdiv class=\"pgc-img\"\u003E\u003Cimg src=\"http:\u002F\u002Fp1.pstatp.com\u002Flarge\u002Fdfic-imagehandler\u002Fef24cf52-441c-4838-acc7-6be76e2f9c17\" img_width=\"1200\" img_height=\"801\" alt=\"前P8程序员留下来面试题干货:关于RabbitMQ「含答案」\" inline=\"0\"\u003E\u003Cp class=\"pgc-img-caption\"\u003E\u003C\u002Fp\u003E\u003C\u002Fdiv\u003E\u003Ch1\u003E\u003Cstrong\u003E一:rabbitmq 的使用场景有哪些?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Col\u003E\u003Cli\u003E跨系统的异步通信,所有需要异步交互的地方都可以使用消息队列。就像我们除了打电话(同步)以外,还需要发短信,发电子邮件(异步)的通讯方式。\u003C\u002Fli\u003E\u003Cli\u003E多个应用之间的耦合,由于消息是平台无关和语言无关的,而且语义上也不再是函数调用,因此更适合作为多个应用之间的松耦合的接口。基于消息队列的耦合,不需要发送方和接收方同时在线。在企业应用集成(EAI)中,文件传输,共享数据库,消息队列,远程过程调用都可以作为集成的方法。\u003C\u002Fli\u003E\u003Cli\u003E应用内的同步变异步,比如订单处理,就可以由前端应用将订单信息放到队列,后端应用从队列里依次获得消息处理,高峰时的大量订单可以积压在队列里慢慢处理掉。由于同步通常意味着阻塞,而大量线程的阻塞会降低计算机的性能。\u003C\u002Fli\u003E\u003Cli\u003E消息驱动的架构(EDA),系统分解为消息队列,和消息制造者和消息消费者,一个处理流程可以根据需要拆成多个阶段(Stage),阶段之间用队列连接起来,前一个阶段处理的结果放入队列,后一个阶段从队列中获取消息继续处理。\u003C\u002Fli\u003E\u003Cli\u003E应用需要更灵活的耦合方式,如发布订阅,比如可以指定路由规则。\u003C\u002Fli\u003E\u003Cli\u003E跨局域网,甚至跨城市的通讯(CDN行业),比如北京机房与广州机房的应用程序的通信。\u003C\u002Fli\u003E\u003C\u002Fol\u003E\u003Cdiv class=\"pgc-img\"\u003E\u003Cimg src=\"http:\u002F\u002Fp1.pstatp.com\u002Flarge\u002Fdfic-imagehandler\u002F15ebc348-af17-4540-b3ec-53e5bee9c7c0\" img_width=\"1200\" img_height=\"798\" alt=\"前P8程序员留下来面试题干货:关于RabbitMQ「含答案」\" inline=\"0\"\u003E\u003Cp class=\"pgc-img-caption\"\u003E\u003C\u002Fp\u003E\u003C\u002Fdiv\u003E\u003Ch1\u003E\u003Cstrong\u003E二: rabbitmq 有哪些重要的角色?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003ERabbitMQ 中重要的角色有:生产者、消费者和代理:\u003C\u002Fp\u003E\u003Cul\u003E\u003Cli\u003E生产者:消息的创建者,负责创建和推送数据到消息服务器;\u003C\u002Fli\u003E\u003Cli\u003E消费者:消息的接收方,用于处理数据和确认消息;\u003C\u002Fli\u003E\u003Cli\u003E代理:就是 RabbitMQ 本身,用于扮演“快递”的角色,本身不生产消息,只是扮演“快递”的角色。\u003C\u002Fli\u003E\u003C\u002Ful\u003E\u003Cdiv class=\"pgc-img\"\u003E\u003Cimg src=\"http:\u002F\u002Fp3.pstatp.com\u002Flarge\u002Fdfic-imagehandler\u002F180aea38-07a4-4c95-a1ac-80fb368a0029\" img_width=\"1200\" img_height=\"799\" alt=\"前P8程序员留下来面试题干货:关于RabbitMQ「含答案」\" inline=\"0\"\u003E\u003Cp class=\"pgc-img-caption\"\u003E\u003C\u002Fp\u003E\u003C\u002Fdiv\u003E\u003Ch1\u003E\u003Cstrong\u003E三:rabbitmq 有哪些重要的组件?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cul\u003E\u003Cli\u003EConnectionFactory(连接管理器):应用程序与Rabbit之间建立连接的管理器,程序代码中使用。\u003C\u002Fli\u003E\u003Cli\u003EChannel(信道):消息推送使用的通道。\u003C\u002Fli\u003E\u003Cli\u003EExchange(交换器):用于接受、分配消息。\u003C\u002Fli\u003E\u003Cli\u003EQueue(队列):用于存储生产者的消息。\u003C\u002Fli\u003E\u003Cli\u003ERoutingKey(路由键):用于把生成者的数据分配到交换器上。\u003C\u002Fli\u003E\u003Cli\u003EBindingKey(绑定键):用于把交换器的消息绑定到队列上。\u003C\u002Fli\u003E\u003C\u002Ful\u003E\u003Ch1\u003E\u003Cstrong\u003E四:rabbitmq 中 vhost 的作用是什么?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003Evhost 可以理解为虚拟 broker ,即 mini-RabbitMQ server。其内部均含有独立的 queue、exchange 和 binding 等,但最最重要的是,其拥有独立的权限系统,可以做到 vhost 范围的用户控制。当然,从 RabbitMQ 的全局角度,vhost 可以作为不同权限隔离的手段(一个典型的例子就是不同的应用可以跑在不同的 vhost 中)。\u003C\u002Fp\u003E\u003Ch1\u003E\u003Cstrong\u003E五:rabbitmq 的消息是怎么发送的?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003E首先客户端必须连接到 RabbitMQ 服务器才能发布和消费消息,客户端和 rabbit server 之间会创建一个 tcp 连接,一旦 tcp 打开并通过了认证(认证就是你发送给 rabbit 服务器的用户名和密码),你的客户端和 RabbitMQ 就创建了一条 amqp 信道(channel),信道是创建在“真实” tcp 上的虚拟连接,amqp 命令都是通过信道发送出去的,每个信道都会有一个唯一的 id,不论是发布消息,订阅队列都是通过这个信道完成的。\u003C\u002Fp\u003E\u003Ch1\u003E\u003Cstrong\u003E六:rabbitmq 怎么保证消息的稳定性?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cul\u003E\u003Cli\u003E提供了事务的功能。\u003C\u002Fli\u003E\u003Cli\u003E通过将 channel 设置为 confirm(确认)模式。\u003C\u002Fli\u003E\u003C\u002Ful\u003E\u003Ch1\u003E\u003Cstrong\u003E七: rabbitmq 怎么避免消息丢失?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003E消息持久化\u003C\u002Fstrong\u003E\u003C\u002Fli\u003E\u003Cli\u003E\u003Cstrong\u003EACK确认机制\u003C\u002Fstrong\u003E\u003C\u002Fli\u003E\u003Cli\u003E\u003Cstrong\u003E设置集群镜像模式\u003C\u002Fstrong\u003E\u003C\u002Fli\u003E\u003Cli\u003E\u003Cstrong\u003E消息补偿机制\u003C\u002Fstrong\u003E\u003C\u002Fli\u003E\u003C\u002Fol\u003E\u003Ch1\u003E\u003Cstrong\u003E八: 要保证消息持久化成功的条件有哪些?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Col\u003E\u003Cli\u003E声明队列必须设置持久化 durable 设置为 true.\u003C\u002Fli\u003E\u003Cli\u003E消息推送投递模式必须设置持久化,deliveryMode 设置为 2(持久)。\u003C\u002Fli\u003E\u003Cli\u003E消息已经到达持久化交换器。\u003C\u002Fli\u003E\u003Cli\u003E消息已经到达持久化队列。\u003C\u002Fli\u003E\u003C\u002Fol\u003E\u003Cp\u003E以上四个条件都满足才能保证消息持久化成功。\u003C\u002Fp\u003E\u003Ch1\u003E\u003Cstrong\u003E九: rabbitmq 持久化有什么缺点?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003E持久化的缺地就是降低了服务器的吞吐量,因为使用的是磁盘而非内存存储,从而降低了吞吐量。可尽量使用 ssd 硬盘来缓解吞吐量的问题。\u003C\u002Fp\u003E\u003Ch1\u003E\u003Cstrong\u003E十:rabbitmq 有几种广播类型?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003E\u003Cstrong\u003E三种广播模式:\u003C\u002Fstrong\u003E\u003C\u002Fp\u003E\u003Col\u003E\u003Cli\u003Efanout: 所有bind到此exchange的queue都可以接收消息(纯广播,绑定到RabbitMQ的接受者都能收到消息);\u003C\u002Fli\u003E\u003Cli\u003Edirect: 通过routingKey和exchange决定的那个唯一的queue可以接收消息;\u003C\u002Fli\u003E\u003Cli\u003Etopic:所有符合routingKey(此时可以是一个表达式)的routingKey所bind的queue可以接收消息;\u003C\u002Fli\u003E\u003C\u002Fol\u003E\u003Ch1\u003E\u003Cstrong\u003E十一:rabbitmq 怎么实现延迟消息队列?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Col\u003E\u003Cli\u003E通过消息过期后进入死信交换器,再由交换器转发到延迟消费队列,实现延迟功能;\u003C\u002Fli\u003E\u003Cli\u003E使用 RabbitMQ-delayed-message-exchange 插件实现延迟功能。\u003C\u002Fli\u003E\u003C\u002Fol\u003E\u003Ch1\u003E\u003Cstrong\u003E十二: rabbitmq 集群有什么用?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003E集群主要有以下两个用途:\u003C\u002Fp\u003E\u003Cul\u003E\u003Cli\u003E高可用:某个服务器出现问题,整个 RabbitMQ 还可以继续使用;\u003C\u002Fli\u003E\u003Cli\u003E高容量:集群可以承载更多的消息量。\u003C\u002Fli\u003E\u003C\u002Ful\u003E\u003Ch1\u003E\u003Cstrong\u003E十三: rabbitmq 节点的类型有哪些?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cul\u003E\u003Cli\u003E磁盘节点:消息会存储到磁盘。\u003C\u002Fli\u003E\u003Cli\u003E内存节点:消息都存储在内存中,重启服务器消息丢失,性能高于磁盘类型。\u003C\u002Fli\u003E\u003C\u002Ful\u003E\u003Ch1\u003E\u003Cstrong\u003E十四: rabbitmq 集群搭建需要注意哪些问题?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cul\u003E\u003Cli\u003E各节点之间使用“--link”连接,此属性不能忽略。\u003C\u002Fli\u003E\u003Cli\u003E各节点使用的 erlang cookie 值必须相同,此值相当于“秘钥”的功能,用于各节点的认证。\u003C\u002Fli\u003E\u003Cli\u003E整个集群中必须包含一个磁盘节点。\u003C\u002Fli\u003E\u003C\u002Ful\u003E\u003Ch1\u003E\u003Cstrong\u003E十五:rabbitmq 每个节点是其他节点的完整拷贝吗?为什么?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003E不是,原因有以下两个:\u003C\u002Fp\u003E\u003Col\u003E\u003Cli\u003E存储空间的考虑:如果每个节点都拥有所有队列的完全拷贝,这样新增节点不但没有新增存储空间,反而增加了更多的冗余数据;\u003C\u002Fli\u003E\u003Cli\u003E性能的考虑:如果每条消息都需要完整拷贝到每一个集群节点,那新增节点并没有提升处理消息的能力,最多是保持和单节点相同的性能甚至是更糟。\u003C\u002Fli\u003E\u003C\u002Fol\u003E\u003Ch1\u003E\u003Cstrong\u003E十六: rabbitmq 集群中唯一一个磁盘节点崩溃了会发生什么情况?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003E如果唯一磁盘的磁盘节点崩溃了,不能进行以下操作:\u003C\u002Fp\u003E\u003Cul\u003E\u003Cli\u003E不能创建队列\u003C\u002Fli\u003E\u003Cli\u003E不能创建交换器\u003C\u002Fli\u003E\u003Cli\u003E不能创建绑定\u003C\u002Fli\u003E\u003Cli\u003E不能添加用户\u003C\u002Fli\u003E\u003Cli\u003E不能更改权限\u003C\u002Fli\u003E\u003Cli\u003E不能添加和删除集群节点\u003C\u002Fli\u003E\u003C\u002Ful\u003E\u003Cp\u003E唯一磁盘节点崩溃了,集群是可以保持运行的,但你不能更改任何东西。\u003C\u002Fp\u003E\u003Ch1\u003E\u003Cstrong\u003E十七: rabbitmq 对集群节点停止顺序有要求吗?\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003ERabbitMQ 对集群的停止的顺序是有要求的,应该先关闭内存节点,最后再关闭磁盘节点。如果顺序恰好相反的话,可能会造成消息的丢失。\u003C\u002Fp\u003E\u003Ch1 class=\"ql-align-center\"\u003E\u003Cstrong\u003E本文到此结束!喜欢的朋友可以帮忙转发文章和关注一下!感谢!\u003C\u002Fstrong\u003E\u003C\u002Fh1\u003E\u003Cp\u003E\u003Cstrong\u003E关于RabbitMq还有一些剖析,已经整理成文档资料,由于篇幅限制就没有全部展现出来,截图如下所示:\u003C\u002Fstrong\u003E\u003C\u002Fp\u003E\u003Cdiv class=\"pgc-img\"\u003E\u003Cimg src=\"http:\u002F\u002Fp1.pstatp.com\u002Flarge\u002Fpgc-image\u002F8c00db6c6d1242f99063f1eeac419a36\" img_width=\"1843\" img_height=\"874\" alt=\"前P8程序员留下来面试题干货:关于RabbitMQ「含答案」\" inline=\"0\"\u003E\u003Cp class=\"pgc-img-caption\"\u003E\u003C\u002Fp\u003E\u003C\u002Fdiv\u003E\u003Cp\u003E还有更多如\u003Cstrong\u003EZookeeper 、Kafka 、MongoDB 、Hbase 等由于平台机制原因,需要这份耗费大量精力,\u003C\u002Fstrong\u003E花费大量时间整理出来的\u003Cstrong\u003EJava核心知识笔记,\u003C\u002Fstrong\u003E欢迎关注笔者\u003Cstrong\u003E,转发后后台私信回复【笔记】\u003C\u002Fstrong\u003E来获取领取方式。\u003C\u002Fp\u003E\u003Cdiv class=\"pgc-img\"\u003E\u003Cimg src=\"http:\u002F\u002Fp1.pstatp.com\u002Flarge\u002Fpgc-image\u002F7efe0d44d36c4ff8872082f57cd424df\" img_width=\"1794\" img_height=\"866\" alt=\"前P8程序员留下来面试题干货:关于RabbitMQ「含答案」\" inline=\"0\"\u003E\u003Cp class=\"pgc-img-caption\"\u003E\u003C\u002Fp\u003E\u003C\u002Fdiv\u003E\u003Cblockquote\u003E\u003Cp\u003E欢迎关注笔者\u003Cstrong\u003E,转发后后台私信回复【笔记】\u003C\u002Fstrong\u003E来获取领取方式。\u003C\u002Fp\u003E\u003C\u002Fblockquote\u003E\u003C\u002Fdiv\u003E"'.slice(6, -6), groupId: '6718341709652034056
相关文章