虾皮一面 2025.9.18
有史以来体验最好的一次面试,面试官全程不打断听我瞎扯,而且还思考了我瞎扯的内容。
- 自我介绍
- 项目拷打(第一次有面试官听我讲方案,还指出方案中的不足)
- gRPC跟HTTP比有什么优势(性能更强;可以像调用本地函数一样调用,节省心智;强类型,HTTP是弱类型)
- gRPC为什么比HTTP性能更好,gRPC不也是用的HTTP2吗(因为gRPC传输的是 protobuf 二进制数据,相比HTTP传输文本格式的json效率高很多;gRPC用的是HTTP2.0,消除了队头阻塞,而且可以多路复用)
- 实现数据库高可用(主从)
- 数据库主从同步怎么实现的(binlog)
- 为什么用binlog就能同步数据,binlog记录的是什么内容(这里没答好,我只回答binlog记录了数据变化,应该分成statement格式,row格式来回答的)
- MySQL的锁有哪几种(表锁,行锁,间隙锁)
- 说一下哪些情况会用到这些锁(给表添加字段会上表锁;定值写数据会用行锁;范围写数据会上间隙锁)
- 慢SQL优化(硬件压力过高整体变慢,升级硬件,增加主机,也可能网络连接数太多,如果部分语句执行过慢,考虑锁竞争,没有走索引,也有可能索引建太多导致需要维护的东西太多)
- Redis高可用方案(集群+主从)
- Redis主从同步存在的问题(异步同步造成的数据丢失)
- Redis做分布式锁是不是会因为主从同步存在的问题导致不安全(肯定回答,然后提了一下Redis官方对此实现了RedLock)
- RedLock做分布式锁的可靠性(比单纯的主从方案可靠性高,但是因为Redis是基于时钟租约的,所以还是存在脑裂问题)
- 接下来聊了几个开源项目,问我有什么看法
- 接上面提到的开源项目,里面有哪些设计值得借鉴的
- 问我提交的pr具体做了什么
- 进程,线程和协程
- 有栈协程和无栈协程的区别(区别如名,是否存在上下文切换)
- Linux中进程通信的方式(共享内存,消息队列,匿名管道,命名管道,Secket)
- 磁盘Raw了解吗(不了解直接过)
- 计算机网络四层模型,以及四层模型对应的协议以及协议的底层实现
- nat转换
- docker和虚拟机的区别
- docker怎么实现的
- 能不能看到docker进程
- docker可以用跟操作系统不同的内核吗
- Linux主机压力过大有什么排查思路(查CPU压力,内存压力,检查占用最多的进程,看状态是否异常,检查网络连接数量)
- 排查用到哪些Linux命令(说了几个,面试官接着问,有没有上手过,我说没有直接跳过)
- 手撕:合并K个有序链表(秒了,但中间出了一些插曲:面试官网断了)
- 反问
酣畅淋漓的拷打,拼尽全力无法战胜Linux命令实操。
唯一想吐槽的就是虾皮的笔试环境。不支持C++ lambda,也不支持结构序列化,写完一坨代码之后竟然无法通过编译。
许愿二面。
---
更新:一面通过。
#发面经攒人品##我的秋招日记#