站酷二面(已挂)
- 自我介绍
- 项目为什么要用Spring框架,好处是什么
- 缓存一致性
- 数据库慢查询优化
- 找出整数中前10大的数字
面试体验巨差,问到缓存一致性的时候,我的回答是,如果要求不允许有不一致情况出现,那么就不要用缓存。否则的话,对于读多写少可以用过期时间+延时双删。然后问我延时双删会出现不一致性的原因是什么,我说sleep的时间设置大了有什么后果,设置小了有什么后果。
然后说我这种解决方法不行,还让我优化。我说那就直接先更新数据库,然后用Rabbit MQ异步更新缓存。高能来了….问我怎么保证MQ消息不丢失。我回答的是发布订阅模式+消息入库+备份交换机,监听消费备份队列。面试官说消息入库代价太大,而且备份解决不了本质问题……还说MQ挂了怎么办?发送消息的服务挂了怎么办?交换机挂了怎么办?
我说那就只能建立MQ集群了,他说集群代价也太大。??????无语
最后告诉我,说监听数据库日志最好,用一个线程去监听操作。我当时就怼回来了,我说线程挂了怎么办?他说挂了新建一个就行了,说这是最优解。????
合着你数据库不会挂,从库不会挂,线程不会挂,都能重启。我回答的MQ就不能重启是吧。你搞主库从库没有代价?真是恶心住我了。
后面的找出前10大的数字,这是我说用排序,可以保证O(N * logN)的复杂度。他不满意,我又说堆排,就问我构建堆和调整堆的复杂度,因为是构建堆O(N),调整堆O(N * logN)。这个答反了。其实这是一个topN的问题,可以用快速选择做到O(N)的复杂度。
总体一面二面下来就是很无语。一面从10.30面试到12.00,整整一个半小时。二面不知道问这个缓存,他想表达什么。🤮
面完没一会,看BOSS直聘上,该职位已关闭…..
#面试#