【Java 面试宝典】带你拿 offer
大家好系列专栏:面试宝典
Java 面试宝典
题一:rabbitmq 中 vhost 的作用是什么?
题二:rabbitmq 的消息是怎么发送的?
题三:rabbitmq 怎么保证消息的稳定性?
题四:rabbitmq 怎么避免消息丢失?
题五:要保证消息持久化成功的条件有哪些?
题六: rabbitmq 持久化有什么缺点?
题一:rabbitmq 中 vhost 的作用是什么?vhost 可以理解为虚拟 broker ,即 mini-RabbitMQ server。其内部均含有独立的 queue、exchange 和 binding 等,但最最重要的是,其拥有独立的权限系统,可以做到 vhost 范围的用户控制。当然,从 RabbitMQ 的全局角度,vhost 可以作为不同权限隔离的手段(一个典型的例子就是不同的应用可以跑在不同的 vhost 中)。
题二:rabbitmq 的消息是怎么发送的?首先客户端必须连接到 RabbitMQ 服务器才能发布和消费消息,客户端和 rabbit server 之间会创建一个 tcp 连接,一旦 tcp 打开并通过了认证(认证就是你发送给 rabbit 服务器的用户名和密码),你的客户端和 RabbitMQ 就创建了一条 amqp 信道(channel),信道是创建在“真实” tcp 上的虚拟连接,amqp 命令都是通过信道发送出去的,每个信道都会有一个唯一的 id,不论是发布消息,订阅队列都是通过这个信道完成的。
题三:rabbitmq 怎么保证消息的稳定性?提供了事务的功能。通过将 channel 设置为 confirm(确认)模式。
题四:rabbitmq 怎么避免消息丢失?消息持久化 ACK 确认机制设置集群镜像模式消息补偿机制
题五:要保证消息持久化成功的条件有哪些?声明队列必须设置持久化 durable 设置为 true.消息推送投递模式必须设置持久化,deliveryMode 设置为 2(持久)。消息已经到达持久化交换器。消息已经到达持久化队列。以上四个条件都满足才能保证消息持久化成功。
题六: rabbitmq 持久化有什么缺点?持久化的缺地就是降低了服务器的吞吐量,因为使用的是磁盘而非内存存储,从而降低了吞吐量。可尽量使用 ssd 硬盘来缓解吞吐量的问题。不断的翻越一座又一座的高山,那样的人生才是我想要的。这一马平川,一眼见底的生活,我不想要,我的人生,我自己书写,余生很长,请多关照,我的人生,敬情期待
https://docs.qq.com/doc/DUGJPaUhObXJrV3ZR这里可领取 Java 全套资料和面试题
评论