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