迈瑞医疗 软开 一面
昨天的面试,今天才想起来要写一个面经。
主要还是围绕着项目来问吧,项目主要是仿着muduo做的高性能服务器。
* 先问线程池,问每个线程都在做什么。
不断调用`epoll_wait`获取当前`Epoll`所管理的监听事件并处理(虽然回答不是这样回答的)
* 怎么分配的工作,如果当前线程管理的这些连接都比较活跃怎么保证高性能
回答的是如果是某一个线程的所有连接都比较活跃的话,可能这个线程中的连接就会大量堵塞。但是其他线程的不会收到印象,如果想要进一步提高性能。就必须重新去调度,将活跃的连接分配给空闲的线程。
* 怎么去重新调度
应该可以在服务器运行期间记录连接的活跃程度,然后重新分配叭。具体怎么做,不太清楚,没有在服务器中用到。
* 那测试过这个服务器吗,真的高性能吗
用webbench测了一下,大概两百来万吧(明显看到面试官笑了一下)然后疯狂找补,说webbench比较简单,不能测试复杂的应用场景。
后来想想,加上单位不就行了,webbench的单位是每分钟的请求数,真算一下C10K,30s,QPS也才三万。
* 你还做了个定时器,拿他来关闭长连接,为什么要这么做
就是如果有连接长时间不活动,就关闭吗,减少服务负载。
* tcp连接不是有个保活机制吗,为什么你要自己做这个呢。
(被误导了)我还以为tcp会自动关闭长连接的,后续查了一下保活机制是指如果长时间没有信息会发探测帧确认连接是否存活。和这个自动关闭连接不冲突啊
* 你这个双缓冲机制实现异步日志库是怎么实现的。
* 服务端和日志端都有一个Buffer,服务端产生的日志不会直接写入日志文件里,而是先写入服务端的Buffer中,经过一段事件或者服务端Buffer满了之后,日志端就会交换Buffer A和Buffer B。然后写入日志文件里
* 为什么不用单缓冲呢
单缓冲的话,主要是在写入和写出时,要加锁。而双缓冲的话,加锁只有交换的时候。
* 你对迈瑞医疗了解吗
不了解,只知道做医疗的,经朋友推荐浅投一下。
* 反问(反问还打断了面试官说话,看着人脸色都黑了)
这两天正阳,本来就是菜狗,然后面试的时候脑袋晕晕的,这下感觉成我浅投一下,人家浅挂一下了。
主要还是围绕着项目来问吧,项目主要是仿着muduo做的高性能服务器。
* 先问线程池,问每个线程都在做什么。
不断调用`epoll_wait`获取当前`Epoll`所管理的监听事件并处理(虽然回答不是这样回答的)
* 怎么分配的工作,如果当前线程管理的这些连接都比较活跃怎么保证高性能
回答的是如果是某一个线程的所有连接都比较活跃的话,可能这个线程中的连接就会大量堵塞。但是其他线程的不会收到印象,如果想要进一步提高性能。就必须重新去调度,将活跃的连接分配给空闲的线程。
* 怎么去重新调度
应该可以在服务器运行期间记录连接的活跃程度,然后重新分配叭。具体怎么做,不太清楚,没有在服务器中用到。
* 那测试过这个服务器吗,真的高性能吗
用webbench测了一下,大概两百来万吧(明显看到面试官笑了一下)然后疯狂找补,说webbench比较简单,不能测试复杂的应用场景。
后来想想,加上单位不就行了,webbench的单位是每分钟的请求数,真算一下C10K,30s,QPS也才三万。
* 你还做了个定时器,拿他来关闭长连接,为什么要这么做
就是如果有连接长时间不活动,就关闭吗,减少服务负载。
* tcp连接不是有个保活机制吗,为什么你要自己做这个呢。
(被误导了)我还以为tcp会自动关闭长连接的,后续查了一下保活机制是指如果长时间没有信息会发探测帧确认连接是否存活。和这个自动关闭连接不冲突啊
* 你这个双缓冲机制实现异步日志库是怎么实现的。
* 服务端和日志端都有一个Buffer,服务端产生的日志不会直接写入日志文件里,而是先写入服务端的Buffer中,经过一段事件或者服务端Buffer满了之后,日志端就会交换Buffer A和Buffer B。然后写入日志文件里
* 为什么不用单缓冲呢
单缓冲的话,主要是在写入和写出时,要加锁。而双缓冲的话,加锁只有交换的时候。
* 你对迈瑞医疗了解吗
不了解,只知道做医疗的,经朋友推荐浅投一下。
* 反问(反问还打断了面试官说话,看着人脸色都黑了)
这两天正阳,本来就是菜狗,然后面试的时候脑袋晕晕的,这下感觉成我浅投一下,人家浅挂一下了。
全部评论
蛮好
一面面了多久呢
是武汉base吗
相关推荐
查看18道真题和解析
点赞 评论 收藏
分享
10-30 17:07
University of California Riverside UE4 点赞 评论 收藏
分享