运维工程师面试题试题集精析.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

运维工程师面试题试题集精析

面试问答题(共20题)

第一题

请简述你在Linux系统中排查一个高CPU占用率问题的完整流程。如果最终定位到是一个Java进程导致的CPU飙高,你会如何进一步分析该Java进程的具体问题?

答案:

确认CPU占用率异常

使用top或htop命令查看整体CPU占用率,确认是否确实存在CPU飙高(如us/sy/wa/hi/si中某项或多项持续超过80%)。

若top中看到某个进程的CPU%持续很高,记录该进程的PID(进程ID)。

定位占用CPU高的进程

若top未直接显示异常进程,可使用pidstat-u1(每秒统计一次进程CPU占用)或psaux--sort=-%cpu(按CPU占用率降序排序)进一步定位。

若CPU占用集中在某个核心(如top中%CPU后跟CPU0、CPU1等),可结合taskset-p`查看进程是否绑定特定CPU核心。

分析进程占用CPU的具体原因

如果是内核线程(PID为方括号,如[kworker/u:0]):

检查是否为硬件问题(如磁盘坏道、内存故障)或内核模块异常,可通过dmesg查看内核日志。

如果是用户态进程:

使用top-H-p`查看该进程的线程级CPU占用,定位到具体的高CPU占用线程(TID)。

将线程TID转换为十六进制(printf%x\n),通过jstackPID|grep-A10-B10查看线程堆栈(Java进程适用),或通过gdb-pPID“threadapplyallbt”`查看线程调用栈(其他语言)。

持续监控与验证

使用vmstat1或iostat-xz1监控系统整体负载、I/O等待、上下文切换等,排除系统级瓶颈(如频繁中断、大量进程调度)。

若问题为偶现,可通过strace-p-c统计系统调用耗时,或perftop-p`分析CPU热点指令。

二、Java进程高CPU问题的进一步分析

若定位到Java进程(PID为pid)导致CPU飙高,按以下步骤深入分析:

确认Java进程基本信息

使用jps-l确认进程对应的主类或jar包名称,避免误杀。

通过ps-ef|grep`查看进程启动参数(如JVM堆大小、GC策略等),检查是否存在配置不当(如堆内存过小导致频繁GC,或线程数过多)。

分析线程级CPU占用

使用top-H-p定位高CPU占用线程(TID),记录线程的CPU%和NI`(优先级)。

将TID转为十六进制(如tid=12345→hex=3039),执行:

jstackpidjstack.log

grep“0x3039”jstack.log-A10-B10查看线程堆栈

常见线程状态分析:

若线程堆栈中包含java.util.concurrent.ThreadPoolExecutor或自定义线程池,可能是任务积压或线程死循环。

若包含sun.nio.ch.ServerSocketChannelImpl等,可能是网络I/O密集型任务阻塞。

若堆栈显示RUNNABLE且代码集中在某业务方法,可能是该方法存在死循环或复杂计算。

使用JVM工具分析

生成线程快照:

jstackpidjstack_timestamp.log

通过工具(如FastThread或手动分析)汇总线程状态(RUNNABLE/BLOCKED/WAITING等),检查是否存在大量线程阻塞或死锁(FoundoneJava-leveldeadlock)。

使用MAT或jhat分析堆内存:

若怀疑内存泄漏导致频繁GC(CPU被GC线程占用),生成堆转储:

jmap-dump:format=b,file=heapdump.hprofpid

使用MAT(MemoryAnalyzerTool)分析对象是否无法回收(如静态Map缓存未清理、循环引用等)。

使用GC日志分析:

检查JVM启动参数是否开启GC日志(如-Xlog:gc*:file=gc.log),通过GCViewer或gceasy分析GC频率、暂停时间,判断是否为GC频繁(如FullGC频繁触发STW,导致CPU短暂飙高)。

使用性能分析工具定位热点代码

使用Arthas或JProfiler:

使用Arthasattach到进程

./as.shpid

查看CPU占用最高的方法

trace-Ecom.xxx.xxx.*–maxDepth10

Arthas的trace命令可实时监控方法调用耗时和次数,定位热点代码。

使用perf生成火焰图:

perfrecord-F99-ppid–call-

文档评论(0)

wkwgq + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档