蚂蚁oceanbase(C++后端开发)一面

===
给了个链接,一些沟通内容都在上面写。

client、server c++开发服务器;
server需要调用哪些api、client呢。(server写了socket() bind() listen() accept() read(),write()   client写了socket(),connect(), read(),write() )

bind调用是干什么的?为什么client没有调用这个?(答了是这个进程要把这个socket绑定到这个端口去做通信,client没做是因为通常采用os自动分配的端口号)。
client可以bind吗?(我说了可以)

本地多个网卡,bind/listen到哪个网卡(说了socketaddr里面包括了ip和port,可能是通过设置不同网卡的ip地址去bind的)

listen和accept的时候都干了什么(说了listen是监听端口事件到来,accept后结束三次握手)

单向关闭tcp怎么去做(说了shutdown好像可以有选项可以选)

shutdown在TCP层面是怎么对应体现(答了四次挥手对应的FIN和FIN-ACK)

===
你说对存储比较感兴趣,了解过什么样的知识。(说了分布式一致算法、并发控制、MVCC、存储模型(B+树、LSM树、简单了解))
对分布式一致性算法了解哪些(答了PAXOS、RAFT, 容忍恶意节点的(BFT/POW))

CAP理论怎么理解(说了和业务场景相关,像zk、etcd这种要求强一致的可能去做服务配置和服务发现的要求CP,redis这种为了保证高可用,可以从读,没有要求强一致,支持AP)。

client到RAFT集群的请求调用你是怎么去做的(按照项目实现去说了)

client发一个请求给leader了,这个时候leader需要做哪些操作(照实说呗)

follower的commitIndex什么时候更新。(收到leader的log的时候更新自己的log以后就更新)

===
做题,leetcode445-链表相加II
写完先说我的dummy节点有问题,不让我直接返回dummy->next;(补一个delete dummy咯)
然后又说除了用栈还有其他方法吗(说了reverselist然后相加,然后再reverse)

===
反问:您做的是哪个方向?ob内部是如何看待社区版和内部版的,有什么不同?





#阿里巴巴秋招##C++工程师##蚂蚁集团##面经#
全部评论
同岗位,大佬您这问得太顶了。是你项目有服务器嘛?
2 回复 分享
发布于 2021-09-08 14:44
难道是做了6.824😃
1 回复 分享
发布于 2021-09-22 18:15
有个问题,我学习过程中发现accept不属于三次握手吧,因为listen在监听到连接请求后会与请求者通信然后将建立好的连接放入链表中,accept是从已经建立好的连接中也就是链表里取出五元组符合的连接。所以listen可以认为是第二次握手,accept不属于三次的任何一次
1 回复 分享
发布于 2021-09-09 20:49
大佬这些知识是学校讲过吗?还是自己自学的?自学的话有啥资料推荐吗?
点赞 回复 分享
发布于 2021-09-08 16:33
这是社招还是校招呀
点赞 回复 分享
发布于 2021-09-08 20:12
大佬去oceanbase了吗
点赞 回复 分享
发布于 2021-09-17 21:38
除了栈应该还有递归吧
点赞 回复 分享
发布于 2022-02-17 03:46
大佬强,不会做的是6.824吧。。
点赞 回复 分享
发布于 2022-02-28 14:57

相关推荐

不愿透露姓名的神秘牛友
11-19 18:19
点赞 评论 收藏
分享
评论
14
101
分享
牛客网
牛客企业服务