关于作者
🐶 程序猿周周
⌨️ 短视频小厂BUG攻城狮
🤺 如果文章对你有帮助,记得关注、点赞、收藏,一键三连哦,你的支持将成为我最大的动力
本文是《后端面试小册子》系列的第 5️⃣ 篇文章,该系列将整理和梳理笔者作为 Java 后端程序猿在日常工作以及面试中遇到的实际问题,通过这些问题的系统学习,也帮助笔者顺利拿到阿里、字节、华为、快手等多个大厂 Offer,也祝愿大家能够早日斩获自己心仪的 Offer。
文章目录
一、概念
1、如何理解一切接文件?
Linux 中所有内容都是以文件的形式保存和管理,包括一切软硬件。 这样做最明显的好处是,开发者仅需要一套 API 和开发工具即可调取 Linux 系统中绝大部分的资源。同时也带来不利之处,如使用任何硬件设备都必须与根目录下某一目录执行挂载操作,否则无法使用。
二、命令
1、说一下用户权限配置?
使用 chown(change mode)
命令修改文件目录的权限,其中读写执行的权限值分别是 4、2、1,同时三组数字包含所有者,同组用户,其他用户的权限。
2、哪些常用命令?
1)pwd:显示当前所在位置;
2)su:申请切换root用户,需要输入root用户密码(sudo su是当前用户暂时申请root权限,需要输入当前用户密码);
3)grep:要搜索的字符串 要搜索的文件 --color : 搜索命令,–color 代表高亮显示;
4)ps -ef || ps -aux:两者的区别是展示格式不同(System V风格和BSD风格);
5)kill -9 [pid] : 销毁进程(-9表示强制停止),先用ps查找进程,然后用kill掉;
6)find :寻找;
7)tar -zcvf :打包并压缩文件 ;tar -xvf 压缩文件 - C 解压的位置 : 解压压缩包;
8)free : 显示系统内存的使用情况,包括物理内存、交换内存(swap)和内核缓冲区内存;
9)wget : 是从远程下载的工具 ; curl ;
10)top : 监控系统状况,比如CPU、内存的使用,显示系统上正在运行的进程 load average(系统负载,就是进程队列的长度);
11)vmstat : 虚拟内存性能监控、CPU 监控。
3、常用命令的参数理解?
[Linux常用命令的常用参数](https://www.cnblogs.com/autoria/p/6123449.html
三、实操
1、有哪些抓包方式?
-
tcpdump https://www.cnblogs.com/fonxian/p/6565209.html
-
wireshark https://blog.csdn.net/hnjb5873/article/details/48657001
2、CPU 负载过高如何处理?
系统平均负载被定义为在特定时间间隔内运行队列中(在 CPU 上运行或者等待运行多少进程)的平均进程数。
如果一个进程满足以下条件则其就会位于运行队列中:
- 它没有在等待 I/O 操作的结果
- 它没有主动进入等待状态(没有调用
wait
) - 没有被停止(如等待终止)
在 Linux 中,进程分为三种状态,一种是阻塞的进程(blocked process),一种是可运行的进程(runnable process),另外就是正在运行的进程(running process)。
进程可运行状态时,它处在一个运行队列 run queue 中,与其他可运行进程争夺 CPU 时间。系统的 load 是指正在运行和准备好运行的进程的总数。 比如现在系统有 2 个正在运行的进程,3 个可运行进程,那么系统的 load 就是 5。load average 就是一定时间内的 load 数量。
一般来说只要每个CPU的当前活动进程数不大于 3 那么系统的性能就是良好的,如果每个 CPU 的任务数大于 5,那么就表示这台机器的性能有严重问题。
排查思路
1)首先通过命令 ps ux
排查哪些进程 cpu 占用率高;
2)查看对应 java 进程的每个线程的 CPU 占用率。通过命令 ps -Lp 15047 cu
;
3)追踪线程内部,查看 load 过高原因。通过命令 jstack 15047
。
当然第三步也可打印线程 jstack pidof java > stack.out
,查找到对应的 threadid,再反查代码。
3、服务响应慢改如何排查?
PS:《后端面试小册子》已整理成册,目前共十三章节,总计约二十万字,欢迎👏🏻关注公众号【程序猿周周】获取电子版和更多学习资料(最新系列文章也会在此陆续更新)。公众号后台可以回复关键词「电⼦书」可获得这份面试小册子。文中所有内容都会在 Github 开源,项目地址 csnotes,如文中存在错误,欢迎指出。如果觉得文章还对你有所帮助,赶紧点个免费的 star 支持一下吧!