首页 > 蚂蚁oceanbase(C++后端开发)一面
头像
dex2jar4script
编辑于 2021-09-07 21:59
+ 关注

蚂蚁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内部是如何看待社区版和内部版的,有什么不同?





更多模拟面试

全部评论

(8) 回帖
加载中...
话题 回帖
历年真题 真题热练榜 24小时
技术(软件)/信息技术类
查看全部

近期精华帖

热门推荐