1.针对线上系统发生oom,该怎么处理?
oom叫内存溢出,一般在指的是堆内存溢出。就是应用程序在运行的过程中试图申请内存空间但是堆内存已经没有足够的空间可供申请就会发生oom。
一般的原因有两种:
1.业务流量激增
突然的业务流量激增导致堆内存空间不足,这个是由于堆内存空间设置不合理或者说没有对应用程序进行过资源评估或者资源评估不合理导致。解决办法就是扩大堆内存的空间,这个区域的大小可以在JVM(Java虚拟机)启动时通过参数-Xmx设置,如果你没有显式设置,则将使用特定平台的默认值。同时需要对程序进行资源建模评估。
2,内存泄漏
可以取到内存的dump文件离线导入mat或者jprofile工具进行分析,找出大对象被哪些对象引用,结合代码一起分析是否有内存泄漏。
2.线上系统cpu飙高怎么办?
1.top -h -p -pid命令查看cpu占用较高的线程
2.printf %x tid进行线程的进制转换,转成16进制,例如找到CPU负载高的线程pid 8627, 把这个数字转换成16进制,21B3(10进制转16进制,用linux命令: printf %x 8627)
3.jstack pid 打印进程中所有线程的运行堆栈,拿线程的16进制编码进行检索,查看堆栈信息,结合代码进行分析。 jstack pid|grep 21B3
版权声明:本文为bluesky588原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。