搞懂这 10 组Java后端面试问题,工作稳了

110 篇文章 2 订阅
63 篇文章 4 订阅

前言:

面试过程是一个由浅入深的过程,面试官先给求职者抛出一个相对简单的问题,然后通过一环套一环的追问深入考察求职者对知识点的理解掌握程度。

如下是一个实际的关于redis知识点的面试场景:

面试官: 你用过redis吗?
你:用过
面试官:你知道redis是单线程还是多线程呢?
你:在4.0之前是单线程,但是在4.0之后开始支持多线程了。
面试官:为什么redis使用了单线程还是那么快?
你:单线程可以避免多线程竞争,内存操作,I/O多路复用机制...
面试官:Redis是如何保证数据不丢失的?
你:redis持久化主要通过AOF、RDB、以及4.0后提供的混合持久化方式实现的
......

通过上面的例子可以看出,一个知识点可以牵扯出很多关联的小知识点,而要掌握所有的面试点是很难的,所以咱们不要轻易说吊打面试官了,一不小心就会被面试官吊起来打,毕竟问题永远比方法多,对吧。

数据库篇

MySQL数据库相关

  • MySQL有哪些常见的存储引擎?
  • 索引的原理是什么?
  • MySQL三种日志分别起到什么作用?(redoLog,undoLog,binLog)
  • 为什么选择B+树索引?
  • 什么情况下会出现索引失效?
  • 如何查看执行计划?
  • 如何优化SQL查询?
  • MySQL主从复制原理?
  • 数据库死锁的原因?如何快速定位并解决?

事务隔离级别

  • 事务有哪些隔离级别?
  • 每种隔离级别会导致什么问题?
  • mysql 和 oracle默认情况下分别采用哪种隔离级别?
  • mysql如何解决幻读的?

中间件篇

MQ的相关问题

  • 你用过消息队列吗?用了哪个消息队列?
  • 在使用MQ的时候怎么确保消息 100% 不丢失?
  • 怎么解决消息的重复消费问题?
  • 如何实现顺序消息?
  • 如何解决引入消息后的事务问题?

分库分表相关问题

  • 你用过分库分表吗?
  • 如何实现单个维度的非sharding-key 的查询问题?比如通过userID 作为 sharding-key,那么如何实现基于userName进行查询?(映射法、基因法)
  • 如何实现多个维度的多个字段非 sharding-key 如何查询?时间、用户名、类别等...
  • 多维度查询需要配合其他查询引擎,那么如何实现数据同步?如何保证双写的一致性?
  • 很多情况下并不是一开始就实现分库分表,等我们需要分库分表的时候如何进行数据迁移?

Redis

  • 用过Redis吗?Redis支持哪些常见的数据结构?
  • Redis的线程模型
  • Redis如何保证数据不丢失的(如何实现持久化)?
  • AOF 和 RDB的实现原理?
  • Redis如何实现高可用?
  • 什么是缓存穿透,缓存击穿,缓存雪崩?分别如何预防解决?

分布式锁相关问题

  • 用过分布式锁吗?用什么实现的分布式锁?
  • 有没有用过基于redis分布式锁?有没有用过基于Zookeeper的分布式锁?
  • 如何给锁设置合理的加锁时间?锁超时了怎么办?Redisson看门狗的原理?
  • Redis如何解决集群情况下分布式锁的可靠性?
  • RedLock算法的原理?

并发编程篇

锁相关

  • 说一下synchronized 底层实现原理?
  • 说一下synchronized、volatile、CAS 的区别?
  • synchronized 和 Lock 有什么区别?
  • 什么是CAS,CAS的原理?
  • CAS有什么缺点?如何解决CAS中常见的ABA问题?
  • AQS的原理,AQS的实现过程是什么?
  • 有没有用过读写锁ReentrantReadWriteLock,说一下ReentrantReadWriteLock的原理?

线程池相关

  • 有哪几类线程池?如何创建线程池?
  • 解释一下线程池的核心参数,线程池的执行过程?
  • 如果提交任务时,线程池队列已满,这时候会发生什么?
  • 线程池线上参数如何优化?

分布式篇

分布式理论

  • 说说你对CAP理论的理解?
  • 说说你用过的注册中心,分别使用了什么模型?(AP,CP)
  • 说说你对BASE理论的理解?

分布式事务相关

  • 如何解决分布式事务问题?你用过哪些解决分布式事务的方案?
  • 说一下对2PC,3PC协议的理解?
  • 有没有用过SEATA,SEATA的实现过程是什么?
  • 如何基于MQ实现最终一致性?

实战篇

  • 如何设计接口并保证他们的安全?
  • 如何快速定位CPU溢出?
  • 如何设计实现一个限流组件?
  • 如何让系统能抗住预约抢购活动的流量压力?

小伙伴们有兴趣想了解内容和更多相关学习资料的请点赞收藏+评论转发+关注我,后面会有很多干货。
我有一些面试题、架构、设计类资料可以说是程序员面试必备!所有资料都整理到网盘了,需要的话欢迎下载!私信我回复【07】即可免费获取

 

原创作者:java大蜗牛

原文出处:zhuanlan.zhihu.com/p/371690431

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值