首页 > 美团后端两面面经
头像
菜鸟201711052124359
编辑于 2020-09-09 19:43
+ 关注

美团后端两面面经

一面

面试时间:2020/09/09  14:00
面试时常:1小时

1.自我介绍
2.说一个你印象比较深刻的项目
讲了自己做的一个博客项目.
3.你刚刚说博客条数用到了数据缓存,那你的数据是怎么更新的?(缓存数据一致性问题)
数据一致性要求不高,缓存过期和缓存依赖
数据一致性要求很高,说了延迟双删

4.你可以讲一讲你在滴滴实习接触的一些技术,或者开源软件什么的,说一下你觉得的发展趋势?
我感觉问题太大了,让面试官举一些例子,面试官说随便说,都可以。
讲了PHP和Go的对比,还有我的看法

5.如果查询很慢的话怎么做优化?
其中我讲了一个分表的例子,在滴滴实习时候。面试官反问,你这样做分别有没有可能把大量数据都弄进来了一张表。
我想了想我的业务,其实company_id是递增的,不太可可能把数据量很大大公公司数据都放到一张表,所以就直说了,应该是面试官想核实我对项目的理解。

5.1 SQL有哪些场景可能不走索引?
这里只想到了两个简单例子,还得补充一下。

6.你最近在看什么书?说细一点。
我说了redis设计原理、设计模式、xss攻击,和一些简单想法;
面试官让我说的细一些;
然后我继续说了数据库隔离级别是怎么实现的?redis为什么那么快,底层数据结构有哪些。

7.你能说一下你是如果通过实践获取经验的吗?(感觉问题好大)
我说了我学习Yii框架,了解了他的原理,然后实习时候用CI框架然后很快就可以上手。

8.你刚刚说的是自己做的项目?有没有跟其他人一起合作的项目?
讲了一个企业微信用车需求改造的例子。

8.1你说你用了缓存,那么一致性问题是怎么保证的?
我的这个业务不需保证,但我说了保证一致性的一些方法。
8.2你和其他后端、前端同学是怎么合作的?
把讨论的结果写在wiki里面,先定方案。

9.说一个你解决的比较难的问题?

10.美团一次下单请求,网络层面或者操作系统层面会发生什么?
我讲了nginx服务器工作还有Yii框架工作...感觉答得不知道对不对。

11.熟悉的设计模式有哪些?

12.tcp为什么能保证它的可靠性?

13.手撕算法题 无序数组找最长的递增序列长度?

14.说了一下想法,时间不够了,面试官问我还有什么问题吗?
反问部门业务

补充:进程的通信方式有哪些?



二面(以为改天约二面,没想到突然接到电话)

面试时间:2020/09/09  16:45
面试时长:1小时

1.面试官看了看电脑不说话,我问需要自我介绍一下吗?
不用,我看了你的简历,直接开始吧.

2.如果你发现请求量突然激增这样的场景你会怎么处理?
事前预警,比如qps超出阈值预警,说了用各类日志数目来指标。
事后,先看看服务器能不能承受的住,想办法止损、切流、把流量打到其他地方去。
检测,看看是什么地方出了问题导致流量激增,是代码有问题还是网络转发有问题,做排查。

3.你说你用了redis做缓存,那么如何保持数据的一致性?

4.redis数据都是存在一台机器上的吗?机器存储量不够怎么办?
我说都是分布在各个机器上的。

5.那么你怎么知道每次取数据去哪台机器取?
我说了没做过这方面问题。
但我觉得有可能是做了标识的,不同数据缓存不同机器。说了我分表时候的想法,不知道对不对。(需要补上)

5.如果缓存宕机了怎么处理?
事先预警;
事后切流定位为题;
说用锁来实现一些预防,在网上看到的,没了解清楚,面试官问了几句,自己回答不出来。(需要补上)

6.如果一段时间后你知道流量会激增?你怎么做?比如特定节日?
业务代码技术
从简单到复杂:
优化业务代码,时间空间复杂度
加缓存或者中间件来流量削峰
换语言,加机器

服务器
做负载均衡

7.那你知道怎么做负载均衡吗?
不知道。

8.ICP调用知道吗?
不知道

9.联合索引(A, B, C)怎么用才能用到索引?
这个详细了解过,说了最左匹配原则,还说了为什么要最左匹配。

10.写一条sql语句
一张表t(id, no, type)输出各种type里面id最大的no

11.用过消息队列吗?
说了实习时候用来处理短信

11.1你刚刚说用到了mq,你的目的是什么,解释一下?
说了解耦和节省接口耗时。(感觉还需要再补充的详细一些,多想一点)

12.怎么保证不重复发送短信?
我的业务重复发送也没关系;
然后想了想,说自己没做过,但是可能会做一个一段时间的缓存,每次发送把标识存进去,如果发现已经发送过了,就不要再发送

13.如果消息队列中数据丢失了怎么办?
没处理过这类问题。
我就说了自己的想法;
第一个,挑选可靠的mq;
第二个,做一些预警处理,比如平时短信业发送量突然下降很多,报警,排查。
(需要补充)

14.说一下装饰器模式,说细一点,什么时候用呢?

15.你觉得用设计模式会有什么坏处?
发懵了一会。
说可读性可能差一些;
如果生搬硬套会感觉非常奇怪,有些场合代码冗余一点其实是可以接受的。
(需要补充)

16.一个账户10块钱,只能花一块,多个人都可以使用这个账户,如果两个人都看到了10块,然后花完发现是8块怎么办?
讲了事务和索,感觉我思路有点乱,重新问了面试官具体的场景,然后自己举例说,上锁,在A花钱的时候,B不能读,等我操作做为了你才能读。

17.你觉得你做开发的优势是什么?

18.你为什么不留在滴滴:

19.你可以说一下你实习时候,小组核心业务是怎么运作的?
挖了一些细节,基本都回答清楚了。

20.你的小组leader对你的优略评价?
做事认真;
要找自感兴趣方向深挖;

21.你对自己优略评价?

22.针对你自己说的缺点你是怎么打算的?
看书,深挖,比如最近看了上面;
争取有机会早点再去实习,实践锻炼。

23.面试官问有什么想问的吗?
问部门业务。

补充:了解多线程吗?可以写多线程代码吗?
多线程抢夺临界资源怎么办?

总的来说感觉面试官们,都挖的很全面,也会对你做的项目提出疑问,你需要对自己的做的事情有一个比较清楚的了解,回答他的疑问。

更多模拟面试

全部评论

(2) 回帖
加载中...
话题 回帖

近期热帖

历年真题 真题热练榜 24小时
技术(软件)/信息技术类
查看全部

近期精华帖

热门推荐