【2023校招】小天才 web后台 一面凉经

  1. 线程池
    1. 参数
    2. 执行过程
    3. 拒绝策略
    4. 场景:四种拒绝策略都是有损的,如何优化。
  2. MySQL
    1. 事务隔离级别
    2. 不可重复读,MySQL 如何避免
    3. SQL 性能分析和优化
    4. 联合索引,最左匹配法则
  3. Spring
    1. 事务传播行为
    2. 事务管理机制:@Transactional
      1. 原理
      2. 注解的参数
      3. 实现原理
      4. 失效情况
  4. Redis
    1. 项目经历(缓存穿透)
    2. 数据结构
    3. 分布式锁
    4. List 了解
    5. LPOP 和 BLPOP 的区别
    6. List 使用场景(实现消息队列),存在的问题
    7. Redis 消息队列和 MQ 的区别
  5. MQ
    1. MQ 项目经历及场景(RocketMQ 解决缓存数据库不一致)
    2. 更新 MySQL 时失败如何处理(重传
    3. RocketMQ 重传机制,上限
    4. 死信队列
  6. open
  7. 反问
#面经##校招##Java##小天才##web后台#
全部评论
同学,可以看看我们公司,招聘软件测试和开发! 深圳市国资全资子公司,研发型企业,纯国资背景,薪资对标深圳大厂薪资。(无笔试,直接面试),感兴趣同学看我的主页帖子,可以私信我。 https://www.nowcoder.com/discuss/1085334
点赞 回复
分享
发布于 2022-11-10 10:04 广东

相关推荐

3.21 web开发工程师(穿戴) 没记录面经,只能回忆一些重点的。1、使用nginx 如何搭建单体项目的后端集群    上来就给我干懵了,我寻思我不是面运维啊。还是支支吾吾地答了一下 。拦截前端请求location /,设置请求头 proxy_set_header,设置转发地址proxy_pass。但是没说到重点的upstream ,于是就只能跳过了。2、Spring的事务失效     答:①事务方法非public修饰        ②非事务方法调用事务方法     解决方案:     既然事务失效的原因是方法内部调用走的是this,而不是代理对象。那我们只要想办法获取代理对象不就可以了嘛。这里,我们可以借助AspectJ来实现。   ③事务传播行为不对   ④事务方法的异常被捕获了    ⑤没加@Service注解 3、分布式锁的实现   答:①redis的setnx实现          ②基于zookeeper的有序节点实现          ③redisson   4、redisson的实现原理    这里没讲好。redisson应该是使用WatchDog实现锁续期,防止业务未完成导致锁过期,后续就无法保证线程并发安全。以UUID+线程id作为key,使用lua脚本删锁和上锁,以及使用redlock防止redis主从复制时,单节点宕机导致锁失效的场景。简单概括了。5、Mysql与redis的数据一致性       刚开始要我介绍了一下点赞的业务,使用redis合并写功能,先把点赞放入redis,在定时获取点赞,写入数据库,mq通知其他服务点赞的数量,后续是否点赞可先通过redis管道命令查询redis 中点赞是否存在,再查数据库,返回是否点赞。这里我寻思他应该问的是这个,我就答了拿到记录后即刻删除掉redis记录,再写入数据库。       没想到他是问缓存与数据库的数据一致性,结果就被喷不合理。后面想了一下确实回答错了,并且我的小说网站是读多写少的场景,先更新数据库,再删缓存,是比较好的,然后中间再通过mq补偿,防止删缓存失败,或者延时双删也行。只不过当时以为问的点赞业务,所以说错了之后,被质疑直接问懵了。        大致就这么多,第二天就秒挂了,寻思也是kpi了,因为没手撕。
点赞 评论 收藏
转发
2 16 评论
分享
牛客网
牛客企业服务