✿ udp调用有什么作用?

命令netstat作用_netstat命令_命令netstat-a

三、操作系统

✿ 进程和线程-分别的概念 区别 适用范围 它们分别的通讯方式 不同通讯方式的区别优缺点

✿ 僵尸进程

✿ 死锁是怎么产生的

✿ CPU的执行方式

✿ 代码中遇到进程阻塞,进程僵死,内存泄漏等情况怎么排查。

✿ 有没有了解过协程?说下协程和线程的区别?

✿ 堆是线程共有还是私有,堆是进程共有还是私有,栈呢

✿ 了解过协程吗(我:携程???不了解呜呜呜)

✿ 共享内存的使用实现原理(必考必问,然后共享内存段被映射进进程空间之后,存在于进程空间的什么位置?共享内存段最大限制是多少?)

✿ c++进程内存空间分布(注意各部分的内存地址谁高谁低,注意栈从高道低分配,堆从低到高分配)

✿ ELF是什么?其大小与程序中全局变量的是否初始化有什么关系(注意.bss段)

✿ 使用过哪些进程间通讯机制,并详细说明(重点)

✿ 多线程和多进程的区别(重点 面试官最最关心的一个问题,必须从cpu调度,上下文切换,数据共享,多核cup利用率,资源占用,等等各方面回答,然后有一个问题必须会被问到:哪些东西是一个线程私有的?答案中必须包含寄存器,否则悲催)

✿ 信号:列出常见的信号,信号怎么处理?

✿ i++是否原子操作?并解释为什么???????

✿ 说出你所知道的各类linux系统的各类同步机制(重点),什么是死锁?如何避免死锁(每个技术面试官必问)

✿ 列举说明linux系统的各类异步机制

✿ exit() _exit()的区别?

✿ 如何实现守护进程?

✿ linux的内存管理机制是什么?

✿ linux的任务调度机制是什么?

✿ 标准库函数和系统调用的区别?

✿ 补充一个坑爹坑爹坑爹坑爹的问题:系统如何将一个信号通知到进程?(这一题哥没有答出来)

命令netstat-a_netstat命令_命令netstat作用

四、Linux系统

✿ Linux的各种命令 给你场景让你解决

✿ Linux了解么,查看进程状态ps,查看cpu状态 top。查看占用端口的进程号 grep

✿ Linux的cpu 100怎么排查,top ,日志,gui工具

✿ Linux操作系统了解么

✿ 怎么查看CPU负载,怎么查看一个客户下有多少进程

✿ Linux内核是怎么实现定时器的

✿ gdb怎么查看某个线程

✿ core dump有没有遇到过,gdb怎么调试

✿ linux如何设置core文件生成

✿ linux如何设置开机自启动

✿ linux用过哪些命令、工具

✿ 用过哪些工具检测程序性能,如何定位性能瓶颈的地方

✿ ipcs ipcrm (如果这四个命令没听说过或者不能熟练使用,基本上可以回家,通过的概率较小 ^_^ ,这四个命令的熟练掌握程度基本上能体现面试者实际开发和调试程序的经验)

✿ cpu 内存 硬盘 等等与系统性能调试相关的命令必须熟练掌握,设置修改权限 tcp网络状态查看 各进程状态 抓包相关等相关命令 必须熟练掌握

✿ awk sed需掌握

✿ gdb调试相关的经验,会被问到

五、

✿ 关于大数据存储的( )各种原理 又问的深入很多

命令netstat-a_netstat命令_命令netstat作用

六、Redis

✿ Redis内存数据库的内存指的是共享内存么

✿ Redis的持久化方式

✿ Redis和MySQL有什么区别,用于什么场景。

✿ redis有没有用过,常用的数据结构以及在业务中使用的场景,redis的hash怎么实现的

✿ 问了下缓存更新的模式,以及会出现的问题和应对思路?

✿ redis的上投票选举的问题 raft算法

✿ redis单线程结构有什么优势?有什么问题? 主要优势单线程,避免线程切换产生静态消耗,缺点是容易阻塞,虽然redis使用io复用epoll和输入缓冲区把命令按照队列先进先出输入等等

✿ 你觉得针对redis这些缺点那些命令在redis上不可使用? 比如keys、等等这些命令 建议用scan等等 这方面阐述

✿ 你觉得为什么项目中没有用mysql而用了es,redis在这里到底起到了什么作用?因为架构上这里理解不清楚,最后回答自己都觉得有漏洞了

✿ 你觉得redis什么算有用? 有用? 是说存进去了还是说命中缓存?最后把缓存命中率是什么说了一遍

✿ 你们这边redis集群是怎么样子的

✿ 平常redis用的多的数据结构是什么,跳表实现,怎么维护索引,当时我说是一个简单的二分,手写二分算法,并且时间复杂度是怎么计算出来的 (2的k次方等于n k等于logn)

命令netstat-a_命令netstat作用_netstat命令

七、MySQL

✿ 你们后端用什么数据库做持久化的?有没有用到分库分表,怎么做的?

✿ 索引的常见实现方式有哪些,有哪些区别?MySQL的存储引擎有哪些,有哪些区别?使用的是什么方式实现索引,怎么实现的?说下聚簇索引和非聚簇索引的区别?

✿ mysql查询优化

✿ MySQL的索引,B+树性质。

✿ B+树和B树,联合索引等原理

✿ mysql的悲观锁和乐观锁区别和应用,ABA问题的解决

✿ 项目性能瓶颈在哪,数据库表怎么设计

✿ 假设项目的性能瓶颈出现在写数据库上,应该怎么解决峰值时写速度慢的问题

✿ 假设数据库需要保存一年的数据,每天一百万条数据,一张表最多存一千万条数据,应该怎么设计表

✿ 数据库自增索引。100台服务器,每台服务器有若干个用户,用户有id,同时会有新用户加入。实现id自增,统计用户个数?不能重复,好像是这样的。

✿ mysql,会考sql语言,服务器数据库大规模数据怎么设计,db各种性能指标

netstat命令_命令netstat-a_命令netstat作用

八、算法

✿ 堆栈

✿ 有序数组排序,二分,复杂度

✿ 常见排序算法,说下快排过程,时间复杂度

✿ 有N个节点的满二叉树的高度。1+logN

✿ 如何实现关键字输入提示,使用字典树,复杂度多少,有没有其他方案,答哈希,如果是中文呢,分词后建立字典树?

✿ 的实现讲一下吧,讲的很详细了。讲一下红黑树的结构,查询性能等。

✿ 快排的时间复杂度,冒泡时间复杂度,快排是否稳定,快排的过程

✿ 100w个数,怎么找到前1000个最大的,堆排序,怎么构造,怎么调整,时间复杂度。

✿ 一个矩阵,从左上角到右下角,每个位置有一个权值。可以上下左右走,到达右下角的路径权值最小怎么走。

✿ 四辆小车,每辆车加满油可以走一公里,问怎么能让一辆小车走最远。说了好几种方案,面试官引导我优化了一下,但是还是不满意,最后他说跳过。

✿ MySQL的索引,B+树性质。

✿ 十亿和数找到前100个最大的,堆排序,怎么实现,怎么调整。

✿ 布隆过滤器

✿ hash表解决冲突的方法

✿ 跳表插入删除过程

✿ 让你实现一个哈希表,怎么做(当时按照Redis中哈希表的实现原理回答)

九、设计模式

✿ 对于单例模式,有什么使用场景了,讲了全局id生成器,他问我分布式id生成器怎么实现,说了zk,问我zk了解原理不,讲了zab,然后就没问啦。

✿ 除了单例模式,知道适配器模式怎么实现么,有什么用

十、分布式架构

✿ CAP BASE理论

✿ 看你项目里面用了etcd,讲解下etcd干什么用的,怎么保证高可用和一致性?

✿ 既然你提到了raft算法,讲下raft算法的基本流程?raft算法里面如果出现脑裂怎么处理?有没有了解过paxos和的zab算法,他们之前有啥区别?

✿ rpc有没有了解

命令netstat-a_命令netstat作用_netstat命令

十一、系统设计

✿ 朋友之间的点对点关系用图维护,怎么判断两人是否是朋友,并查集,时间复杂度,过程。

✿ 10g文件,只有2g内存,怎么查找文件中指定的字符串出现位置。

✿ Linux大文件怎么查某一行的内容。

✿ 秒杀系统的架构设计

✿ 十亿个数的集合和10w个数的集合,如何求它们的交集。

✿ 回到网络,刚才你说到直播场景,知道直播的架构怎么设计么,要点是什么,说了几个不太对,他说要避免广播风暴,答不会。

✿ 针对自己最熟悉的项目,画出项目的架构图,主要的数据表结构,项目中使用到的技术点,项目的总峰值qps,时延,以及有没有分析过时延出现的耗时分别出现在什么地方,项目有啥改进的地方没有?

✿ 如果请求出现问题没有响应,如何定位问题,说下思路?

✿ 除了公司项目之外,业务有没有研究过知名项目或做出过贡献?

✿ go程和线程有什么区别?

答:1 起一个go程大概只需要4kb的内存,起一个Java线程需要1.5MB的内存;go程的调度在用户态非常轻量,Java线程的切换成本比较高。接着问为啥成本比较高?因为Java线程的调度需要在用户态和内核态切换所以成本高?为啥在用户态和内核态之间切换调度成本比较高?简单说了下内核态和用户态的定义。接着问,还是没有明白为啥成本高?心里瞬间崩溃,没完没了了呀,OS这块依旧是痛呀,支支吾吾半天放弃了。

✿ 服务器CPU 100%怎么定位?

可能是由于平时定位业务问题的思维定势,加之处于蒙蔽状态,随口就是:先查看监控面板看有无突发流量异常,接着查看业务日志是否有异常,针对%那个时间段,取一个典型业务流程的日志查看。最后才提到使用top命令来监控看是哪个进程占用到100%。果然阵脚大乱,张口就来,捂脸。。。 本来正确的思路应该是先用top定位出问题的进程,再用top定位到出问题的线程,再打印线程堆栈查看运行情况,这个流程换平时肯定能答出来,但是,但是没有但是。还是得好好总结。

✿ 最后问了一个系统设计题目(朋友圈的设计),白板上面画出系统的架构图,主要的表结构和讲解主要的业务流程,如果用户变多流量变大,架构将怎么扩展,怎样应对? 这个答的也有点乱,直接上来自顾自的用了一个通用的架构,感觉毫无亮点。后面反思应该先定位业务的特点,这个业务明显是读多写少,然后和面试官沟通一期刚开始的方案的用户量,性能要求,单机目标qps是什么等等?在明确系统的特点和约束之后再来设计,而不是一开始就是用典型互联网的那种通用架构自顾自己搞自己的方案。

✿ 设计一个限流的算法

✿ 定时器除了小根堆,还可以怎么做

✿ 项目性能瓶颈在哪,数据库表怎么设计

✿ .在高并发的生产环境中(非调试场景下),如果出现数据包的丢失,如何定位问题

✿ 补充一个最最重要,最最坑爹,最最有难度的一个题目:一个每秒百万级访问量的互联网服务器,每个访问都有数据计算和I/O操作,如果让你设计,你怎么设计?

netstat命令_命令netstat-a_命令netstat作用

道友总结

———END———
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,永久会员只需109元,全站资源免费下载 点击查看详情
站 长 微 信: nanadh666

声明:1、本内容转载于网络,版权归原作者所有!2、本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。3、本内容若侵犯到你的版权利益,请联系我们,会尽快给予删除处理!