虾皮一面 2025.9.18

有史以来体验最好的一次面试,面试官全程不打断听我瞎扯,而且还思考了我瞎扯的内容。

  1. 自我介绍
  2. 项目拷打(第一次有面试官听我讲方案,还指出方案中的不足)
  3. gRPC跟HTTP比有什么优势(性能更强;可以像调用本地函数一样调用,节省心智;强类型,HTTP是弱类型)
  4. gRPC为什么比HTTP性能更好,gRPC不也是用的HTTP2吗(因为gRPC传输的是 protobuf 二进制数据,相比HTTP传输文本格式的json效率高很多;gRPC用的是HTTP2.0,消除了队头阻塞,而且可以多路复用)
  5. 实现数据库高可用(主从)
  6. 数据库主从同步怎么实现的(binlog)
  7. 为什么用binlog就能同步数据,binlog记录的是什么内容(这里没答好,我只回答binlog记录了数据变化,应该分成statement格式,row格式来回答的)
  8. MySQL的锁有哪几种(表锁,行锁,间隙锁)
  9. 说一下哪些情况会用到这些锁(给表添加字段会上表锁;定值写数据会用行锁;范围写数据会上间隙锁)
  10. 慢SQL优化(硬件压力过高整体变慢,升级硬件,增加主机,也可能网络连接数太多,如果部分语句执行过慢,考虑锁竞争,没有走索引,也有可能索引建太多导致需要维护的东西太多)
  11. Redis高可用方案(集群+主从)
  12. Redis主从同步存在的问题(异步同步造成的数据丢失)
  13. Redis做分布式锁是不是会因为主从同步存在的问题导致不安全(肯定回答,然后提了一下Redis官方对此实现了RedLock)
  14. RedLock做分布式锁的可靠性(比单纯的主从方案可靠性高,但是因为Redis是基于时钟租约的,所以还是存在脑裂问题)
  15. 接下来聊了几个开源项目,问我有什么看法
  16. 接上面提到的开源项目,里面有哪些设计值得借鉴的
  17. 问我提交的pr具体做了什么
  18. 进程,线程和协程
  19. 有栈协程和无栈协程的区别(区别如名,是否存在上下文切换)
  20. Linux中进程通信的方式(共享内存,消息队列,匿名管道,命名管道,Secket)
  21. 磁盘Raw了解吗(不了解直接过)
  22. 计算机网络四层模型,以及四层模型对应的协议以及协议的底层实现
  23. nat转换
  24. docker和虚拟机的区别
  25. docker怎么实现的
  26. 能不能看到docker进程
  27. docker可以用跟操作系统不同的内核吗
  28. Linux主机压力过大有什么排查思路(查CPU压力,内存压力,检查占用最多的进程,看状态是否异常,检查网络连接数量)
  29. 排查用到哪些Linux命令(说了几个,面试官接着问,有没有上手过,我说没有直接跳过)
  30. 手撕:合并K个有序链表(秒了,但中间出了一些插曲:面试官网断了)
  31. 反问

酣畅淋漓的拷打,拼尽全力无法战胜Linux命令实操。

唯一想吐槽的就是虾皮的笔试环境。不支持C++ lambda,也不支持结构序列化,写完一坨代码之后竟然无法通过编译。

许愿二面。

---

更新:一面通过。

#发面经攒人品##我的秋招日记#
全部评论

相关推荐

03-24 17:57
门头沟学院 Java
yakuso:你这头像哈哈哈
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
03-20 12:46
瘦嘟嘟右卫门:百度文库网盘的暑期也没约面吗
点赞 评论 收藏
分享
评论
4
9
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务