首页 > 编程语言 > 详细

JAVA-内存及CPU排查

时间:2018-02-23 10:13:36      阅读:210      评论:0      收藏:0      [点我收藏+]
1.现象
CPU利用率高.
应用缓慢或无法对外提供服务.
2.原因
1.死循环
2.JVM堆占用过大-高频率FULL-GC
3.排查方法
1.使用top命令找出CPU消耗最大的进程
2.使用top -Hp 进程(上一步得到的进程号),找出消耗CPU的线程.
3.使用[jstack 进程与jstat -gcutil 进程 1000 100],找出线程在执行何种操作..
如果线程非GC线程,则直接可以根据调用堆栈找出具体的代码...
否则进行如下操作.
1.jstat -gcutil pid 1000 100用此命令跟踪GC回收...
4.jmap -dump:format=b,file=memoryfile.bin 【pid】
5.sz memoryfile.bin
6.使用mat打开memoryfile.bin文件.然后分析内存.找出内存问题解决..
4.实战
技术分享图片
 
技术分享图片
 
技术分享图片
 
技术分享图片
 
 
技术分享图片
 
技术分享图片
 
5.线上实例
 
技术分享图片
 
技术分享图片
 
 
技术分享图片
 
 
技术分享图片
 
 
六.例子源码
 
import java.util.LinkedList;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class TestMemory{
//private static byte[] byteArray=new byte[1024*1024*170];
private static List<Object> linkList=new LinkedList<Object>();
private static long count=1024*1024*240/56;
//private static List<Object> list=new CopyOnWriteArrayList<Object>();
public static void main(String[] args) throws Throwable{
for(int index=0;index<count;++index){
linkList.add(new Object ());
}
ExecutorService service= Executors.newFixedThreadPool(5);
for (int index=0;index<5;++index) {
service.submit(new Runnable() {
public void run() {
while (true) {
try {
Thread.sleep(100);
test();
} catch (Throwable throwable) {
throwable.printStackTrace();
}
}
}
});
}
System.in.read();
}
private static void test(){
byte[] bytes=new byte[1024*1024];
System.out.printf(bytes.toString());
}
}
 
 
 
public class TestProfile {
private Map<TestHashCode,Object> map=new HashMap<TestHashCode,Object>();
private static Object obj=new Object();
public static void main(String[] args) throws Throwable {
new TestProfile().test1();
}
 
public void test1() throws Throwable{

JAVA-内存及CPU排查

原文:https://www.cnblogs.com/hhbk/p/8460846.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!