Linux面试题总结(2022最新版)

2年前 (2022) 程序员胖胖胖虎阿
320 0 0

Linux面试题总结(2022最新版)

关于作者
🐶 程序猿周周
⌨️ 短视频小厂BUG攻城狮
🤺 如果文章对你有帮助,记得关注、点赞、收藏,一键三连哦,你的支持将成为我最大的动力


关于本文
本文是 Java 面试总结系列的第5️⃣篇文章,该专栏将整理和梳理笔者作为 Java 后端程序猿在日常工作以及面试中遇到的实际问题,通过这些问题的系统学习,也帮助笔者顺利拿到阿里、字节、华为、快手等Offer,也祝愿大家能够早日斩获自己心仪的Offer。由于笔者能力有限,如若有错误或疏忽还望各位大佬们不吝指出…

标题 地址
MySQL数据库面试题总结(2022版) https://blog.csdn.net/adminpd/article/details/122910606
Redis面试题总结(2022版) https://blog.csdn.net/adminpd/article/details/122934938
计算机网络面试题总结(2022版) https://blog.csdn.net/adminpd/article/details/122973684
操作系统面试题总结(2022版) https://blog.csdn.net/adminpd/article/details/122994599
Linux面试题总结(2022版) https://blog.csdn.net/adminpd/article/details/122994862
Spring面试题总结(2022版) https://blog.csdn.net/adminpd/article/details/123016872
Java基础面试题总结(2022版) https://blog.csdn.net/adminpd/article/details/123080189

文章目录

  • 一、概念
      • 1、如何理解一切接文件?
  • 二、命令
      • 1、说一下用户权限配置?
      • 2、哪些常用命令?
      • 3、常用命令的参数理解?
  • 三、实操
      • 1、有哪些抓包方式?
      • 2、CPU 负载过高如何处理?
      • 3、服务响应慢改如何排查?

一、概念

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 监控。

ref

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,再反查代码。

cpu load过高问题排查

3、服务响应慢改如何排查?

版权声明:程序员胖胖胖虎阿 发表于 2022年9月13日 上午5:24。
转载请注明:Linux面试题总结(2022最新版) | 胖虎的工具箱-编程导航

相关文章

暂无评论

暂无评论...