美团后端两面面经
一面
面试时间:2020/09/09 14:00
面试时常:1小时
2.说一个你印象比较深刻的项目
讲了自己做的一个博客项目.
3.你刚刚说博客条数用到了数据缓存,那你的数据是怎么更新的?(缓存数据一致性问题)
数据一致性要求不高,缓存过期和缓存依赖
数据一致性要求很高,说了延迟双删
我感觉问题太大了,让面试官举一些例子,面试官说随便说,都可以。
讲了PHP和Go的对比,还有我的看法
5.如果查询很慢的话怎么做优化?
讲了PHP和Go的对比,还有我的看法
5.如果查询很慢的话怎么做优化?
其中我讲了一个分表的例子,在滴滴实习时候。面试官反问,你这样做分别有没有可能把大量数据都弄进来了一张表。
我想了想我的业务,其实company_id是递增的,不太可可能把数据量很大大公公司数据都放到一张表,所以就直说了,应该是面试官想核实我对项目的理解。
我想了想我的业务,其实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.说了一下想法,时间不够了,面试官问我还有什么问题吗?
反问部门业务
补充:进程的通信方式有哪些?
5.如果缓存宕机了怎么处理?
事先预警;
事后切流定位为题;
说用锁来实现一些预防,在网上看到的,没了解清楚,面试官问了几句,自己回答不出来。(需要补上)
6.如果一段时间后你知道流量会激增?你怎么做?比如特定节日?
业务代码技术
从简单到复杂:
优化业务代码,时间空间复杂度
加缓存或者中间件来流量削峰
#美团##校招##C++工程师##面经#我说了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.那么你怎么知道每次取数据去哪台机器取?
我说了没做过这方面问题。
但我觉得有可能是做了标识的,不同数据缓存不同机器。说了我分表时候的想法,不知道对不对。(需要补上)
1.面试官看了看电脑不说话,我问需要自我介绍一下吗?
不用,我看了你的简历,直接开始吧.
2.如果你发现请求量突然激增这样的场景你会怎么处理?
事前预警,比如qps超出阈值预警,说了用各类日志数目来指标。
事后,先看看服务器能不能承受的住,想办法止损、切流、把流量打到其他地方去。
检测,看看是什么地方出了问题导致流量激增,是代码有问题还是网络转发有问题,做排查。
3.你说你用了redis做缓存,那么如何保持数据的一致性?
4.redis数据都是存在一台机器上的吗?机器存储量不够怎么办?
我说都是分布在各个机器上的。
5.那么你怎么知道每次取数据去哪台机器取?
我说了没做过这方面问题。
但我觉得有可能是做了标识的,不同数据缓存不同机器。说了我分表时候的想法,不知道对不对。(需要补上)
5.如果缓存宕机了怎么处理?
事先预警;
事后切流定位为题;
说用锁来实现一些预防,在网上看到的,没了解清楚,面试官问了几句,自己回答不出来。(需要补上)
6.如果一段时间后你知道流量会激增?你怎么做?比如特定节日?
业务代码技术
从简单到复杂:
优化业务代码,时间空间复杂度
加缓存或者中间件来流量削峰
换语言,加机器
服务器
做负载均衡
7.那你知道怎么做负载均衡吗?
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.你觉得用设计模式会有什么坏处?
发懵了一会。
说可读性可能差一些;
如果生搬硬套会感觉非常奇怪,有些场合代码冗余一点其实是可以接受的。
(需要补充)
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.你可以说一下你实习时候,小组核心业务是怎么运作的?
讲了事务和索,感觉我思路有点乱,重新问了面试官具体的场景,然后自己举例说,上锁,在A花钱的时候,B不能读,等我操作做为了你才能读。
17.你觉得你做开发的优势是什么?
18.你为什么不留在滴滴:
19.你可以说一下你实习时候,小组核心业务是怎么运作的?
挖了一些细节,基本都回答清楚了。
20.你的小组leader对你的优略评价?
做事认真;
要找自感兴趣方向深挖;
21.你对自己优略评价?
22.针对你自己说的缺点你是怎么打算的?
看书,深挖,比如最近看了上面;
争取有机会早点再去实习,实践锻炼。
23.面试官问有什么想问的吗?
问部门业务。
补充:了解多线程吗?可以写多线程代码吗?
多线程抢夺临界资源怎么办?
总的来说感觉面试官们,都挖的很全面,也会对你做的项目提出疑问,你需要对自己的做的事情有一个比较清楚的了解,回答他的疑问。
20.你的小组leader对你的优略评价?
做事认真;
要找自感兴趣方向深挖;
21.你对自己优略评价?
22.针对你自己说的缺点你是怎么打算的?
看书,深挖,比如最近看了上面;
争取有机会早点再去实习,实践锻炼。
23.面试官问有什么想问的吗?
问部门业务。
补充:了解多线程吗?可以写多线程代码吗?
多线程抢夺临界资源怎么办?
总的来说感觉面试官们,都挖的很全面,也会对你做的项目提出疑问,你需要对自己的做的事情有一个比较清楚的了解,回答他的疑问。