- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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-
您可能关注的文档
最近下载
- 汽车底盘构造与维修教案.doc VIP
- 人教版七年级上册数学期末动点问题压轴题专题训练.docx VIP
- GB50173-2014《电气装置安装工程66KV及以下架空电力线路施工及验收规范》.docx VIP
- 1.1 空间向量及其运算(大单元教学设计) 高二数学(人教A版选择性必修第一册).docx
- 2024安徽职业技术学院招聘笔试真题含答案详解.docx VIP
- 山洋伺服电机rs2快速入门手册.pdf VIP
- 生活中的方向第1课时教室里的方向(课件)数学苏教版二年级上册(新教材).pptx VIP
- 宫殿记忆法:提升术.pptx VIP
- 【小学英语】3-6年级整个英语语法体系11页.pdf VIP
- 2025中级经济师《经济基础知识》三色笔记.pdf VIP
文档评论(0)