贵有恒,何必三更起、五更眠、最无益,只怕一日曝、十日寒。这篇文章主要讲述线上排除问题流程相关的知识,希望能为你提供帮助。
【线上排除问题流程】
排查CPU占用高的代码
1. 编写代码
public class Demo
public static void main(String[] args)
System.err.println("测试开始");
while(true)
编写一个死循环代码。
执行此代码
2.找到CPU占用率高的进程我们可以观察到top查看cpu占用高的进程。
找到cpu占用率为 100%的线程。
3.导出执行堆栈 jstack 3417 > > java.txt
3417 为进程号
4.查占用率高的线程top -H -p 3417
找到线程号 为3418
5.转换16进制 printf "%x\\n" 3418
执行后 为 d5a
6.在之前导出的堆栈文件查找查找d5a
"main" #1 prio=5 os_prio=0 tid=0x00007f3ef804b000 nid=0xd5a runnable [0x00007f3efef94000]
java.lang.Thread.State: RUNNABLE
at Demo.main(Demo.java:4)
发现是我们的Demo第四行出了问题,这样找回源码,去掉死循环即可。
推荐阅读
- DRT移植各种成熟稳定的C工具包到DELPHI
- navicat给datetime设置默认值
- Ingress 大全20220426
- 创业如何产生一个足以成立公司的「创意」呢()
- Deployment 大全20220423
- 面试必问 | 哪些场景下Spring的事务会失效()
- Angular的nz-zorro升级
- SkyWalking--使用/教程/实例
- k8s部署-46-k8s共享存储(下)