互联网企业都会碰到的63道面试题:RabbitMQ+Kafka+Zookeeper+Redis+JVM
小编精心收集:专为银十招聘季准备,以下面试题先过一遍,为即将到了的面试做好准备,也过一遍基础知识点。
一、RabbitMQ
- rabbitmq 的使用场景有哪些?
- rabbitmq 有哪些重要的角色?
- .rabbitmq 有哪些重要的组件?
- rabbitmq 中 vhost 的作用是什么?
- rabbitmq 的消息是怎么发送的?
- rabbitmq 怎么保证消息的稳定性?
- rabbitmq 怎么避免消息丢失?
- 要保证消息持久化成功的条件有哪些?
- rabbitmq 持久化有什么缺点?
- .rabbitmq 有几种广播类型?
- rabbitmq 怎么实现延迟消息队列?
- rabbitmq 集群有什么用?
- rabbitmq 节点的类型有哪些?
- rabbitmq 集群搭建需要注意哪些问题?
- rabbitmq 每个节点是其他节点的完整拷贝吗?为什么?
- rabbitmq 集群中唯一一个磁盘节点崩溃了会发生什么情况?
- rabbitmq 对集群节点停止顺序有要求吗?
二、Kafka
- kafka 可以脱离 zookeeper 单独使用吗?为什么?
- kafka 有几种数据保留的策略?
- kafka 同时设置了 7 天和 10G 清除数据,到第五天的时候消息达到了 10G,这个时候 kafka 将如何处理?
- 什么情况会导致 kafka 运行变慢?
- 使用 kafka 集群需要注意什么?
三、Zookeeper
- zookeeper 是什么?
- zookeeper 都有哪些功能?
- zookeeper 有几种部署模式?
- zookeeper 怎么保证主从节点的状态同步?
- 集群中为什么要有主节点?
- 集群中有 3 台服务器,其中一个节点宕机,这个时候 zookeeper 还可以使用吗?
- 说一下 zookeeper 的通知机制?
四、MySql
- 数据库的三范式是什么?
- 一张自增表里面总共有 7 条数据,删除了最后 2 条数据,重启 mysql 数据库,又插入了一条数据,此时 id 是几?
- 如何获取当前数据库版本?
- 说一下 ACID 是什么?
- char 和 varchar 的区别是什么?
- float 和 double 的区别是什么?
- mysql 的内连接、左连接、右连接有什么区别?
- mysql 索引是怎么实现的?
- 怎么验证 mysql 的索引是否满足需求?
- 说一下数据库的事务隔离?
- 说一下 mysql 常用的引擎?
- 说一下 mysql 的行锁和表锁?
- 说一下乐观锁和悲观锁?mysql 问题排查都有哪些手段?
- 如何做 mysql 的性能优化?
五、Redis
- redis 是什么?都有哪些使用场景?
- redis 有哪些功能?
- redis 和 memecache 有什么区别?
- redis 为什么是单线程的?
- 什么是缓存穿透?怎么解决?
- redis 支持的数据类型有哪些?
- redis 支持的 java 客户端都有哪些?
- jedis 和 redisson 有哪些区别?
- 怎么保证缓存和数据库数据的一致性?
- redis 持久化有几种方式?
- redis 怎么实现分布式锁?
- redis 分布式锁有什么缺陷?
- redis 如何做内存优化?
- redis 淘汰策略有哪些?
- redis 常见的性能问题有哪些?该如何解决?
六、JVM
- 说一下 jvm 的主要组成部分?及其作用?
- 说一下 jvm 运行时数据区?
- 说一下堆栈的区别?
- 队列和栈是什么?有什么区别?
- 什么是双亲委派模型?
- 说一下类加载的执行过程?
- 怎么判断对象是否可以被回收?
- java 中都有哪些引用类型?
- 说一下 jvm 有哪些垃圾回收算法?
- 说一下 jvm 有哪些垃圾回收器?
- 详细介绍一下 CMS 垃圾回收器?
- 新生代垃圾回收器和老生代垃圾回收器都有哪些?有什么区别?
- 简述分代垃圾回收器是怎么工作的?
- 说一下 jvm 调优的工具?
- 常用的 jvm 调优的参数都有哪些?
最后
答案就不立马公布了,将在明天公布,敬请关注。