亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

JAVA運行時問題診斷-工具應用篇

2019-11-14 15:40:29
字體:
來源:轉載
供稿:網友

該BLOG內容是之前在部門組織討論運行時問題時自己寫的PPT內容,內容以點帶面,主要是方便以后自己回顧查看。

大綱包括:1、運行時問題分類 2、服務器自帶工具 3、其他工具 4、例子 5、實際情況

運行時問題分類-軟件角度:1、內存泄漏,對象未釋放 2、線程阻塞、死鎖 3、線程死循環 4、網絡IO連接超時時間過長 5、磁盤不可寫 .....

運行時問題分類-硬件角度:1、內存占用高 2、CPU占用高 3、網絡無反應 4、硬盤空間滿 ....

linux指令:1、top, top -Hp pid 2、free 3、df 4、netstat, netstat -natp ...

JDK指令:1、jps, jps -v 2、jstack, jstack pid 3、jmap, jmap -dump:format=b,file=/opt/...  4、jstat, jstat -gcutil(gc,gccapacity) pid ....

工具:

實時分析工具: 1、Jconsole 2、VisualVM  3、JPRofiler  4、javaMelody  5、LambdaProbe ....

離線分析工具: 1、MemoryAnalyzer tool  2、Thread Dump Analyzer ....

DEMO:1、內存溢出  2、CPU占用過高  3、線程死鎖  4、線程阻塞

準備工作:堆棧內存設置低一點,打印GC日志和OOM時輸出dump文件: set JAVA_OPTS=-server -Xms24m -Xmx50m -XX:PermSize=28M -XX:MaxPermSize=80m -XX:+PrintGCDetails -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=d:/temp/dump

內存溢出:

        Map<String, Person> map = new HashMap<String, Person>();        Object[] array = new Object[1000000];        for (int i = 0; i < 1000000; i++) {            String d = new Date().toString();            Person p = new Person(d, i);            map.put(i + "person", p);            array[i] = p;        }

MAT-關鍵字(個人理解,不一定準確):

Histogram:內存中的類對象實例的對象的個數和大小

Dominator Tree:堆對象樹,對象大小和占用百分比

Leak Suspects:MAT分析的內存泄漏的可疑點

shallow heap:對象自身占用內存大小

retained heap:對象自身和引用的對象占用內存大小

Merge Shortest Paths to GC Roots:從GC根節點到該對象的路徑視圖

with outgoing references:對象持有的外部對象引用

with incomming references:對象被哪些外部對象引用

....

 

CPU占用過高:

		int i = 0;		while (i < 1000000) {			i++;			System.out.println(i);			try {				Thread.sleep(0);			} catch (InterruptedException e) {				// TODO Auto-generated catch block				e.printStackTrace();			}		}

  

 

線程死鎖:

		Thread t1 = new Thread(new SyncThread(obj1, obj2), "t1");		Thread t2 = new Thread(new SyncThread(obj2, obj1), "t2");		t1.start();		try {			Thread.sleep(3000);		} catch (InterruptedException e) {			// TODO Auto-generated catch block			e.printStackTrace();		}		t2.start();		synchronized (obj1) {			System.out.println("主線程 lock on " + obj1.getName());		}

  

	private Person obj1;	private Person obj2;	public SyncThread(Person o1, Person o2) {		this.obj1 = o1;		this.obj2 = o2;	}	public void run() {		String name = Thread.currentThread().getName();		System.out.println(name + " acquiring lock on " + obj1.getName());		synchronized (obj1) {			System.out.println(name + " acquired lock on " + obj1.getName());			work();			System.out.println(name + " acquiring lock on " + obj2.getName());			synchronized (obj2) {				System.out.println(name + " acquired lock on " + obj2.getName());				work();			}			System.out.println(name + " released lock on " + obj2.getName());		}		System.out.println(name + " released lock on " + obj1.getName());		System.out.println(name + " finished execution.");	}	private void work() {		try {			Thread.sleep(10000);		} catch (InterruptedException e) {			e.printStackTrace();		}	}

  

 

線程阻塞:

		WaitThread thread1 = new WaitThread();		thread1.setName("線程1");		NotifyThread thread2 = new NotifyThread();		thread2.setName("線程2");		thread1.start();		try {			Thread.sleep(20000);		} catch (InterruptedException e) {			e.printStackTrace();		}		thread2.start();

  

public class NotifyThread extends Thread {	@Override	public void run() {		synchronized (RequestThreadWait.object) {			System.out.println("線程" + Thread.currentThread().getName() + "占用了鎖");			try {				Thread.sleep(20000);			} catch (InterruptedException e) {				// TODO Auto-generated catch block				e.printStackTrace();			}			RequestThreadWait.object.notify();			System.out.println("線程" + Thread.currentThread().getName() + "調用了object.notify()");			try {				Thread.sleep(20000);			} catch (InterruptedException e) {				// TODO Auto-generated catch block				e.printStackTrace();			}		}		System.out.println("線程" + Thread.currentThread().getName() + "釋放了鎖");	}}public class WaitThread extends Thread {	public void run() {		synchronized (RequestThreadWait.object) {			System.out.println("線程" + Thread.currentThread().getName() + "獲取到了鎖開始");			try {				RequestThreadWait.object.wait();			} catch (InterruptedException e) {			}			System.out.println("線程" + Thread.currentThread().getName() + "獲取到了鎖結束!");		}	}}

  

線程狀態(個人理解,不一定準確):

WAITING (parking):線程自身掛起等待,正常

WAITING (on object monitor):線程主動執行wait,等待資源,如果是自己的程序,需要關注

BLOCKED (on object monitor):線程阻塞,等待對方釋放資源,如果是互相等待對方阻塞的線程,則發生死鎖

TIMED_WAITING (on object monitor):線程調用了wait(long timeout),在特定時間內等待

TIMED_WAITING (sleeping):調用了sleeping,休眠一段時間

 

JavaMelody:

LambdaProbe

 

實際情況:

用戶反饋各種千奇百怪的問題!

網絡訪問連接不上

網站、接口訪問超時

特定功能很慢

部分功能部分人打不開

.......

->

ping,telnet,traceroute....

top,top -Hp pid,jstack pid....

jstat -gc,gcutil,gccapacity pid...

jmap -dump:format=b,file=/opt/.... tail, df -lh....

netstat -natp....

.....

生產問題沒有統一解決辦法,具體問題具體分析

內存查看:jstat

線程情況查看:top -Hp pid

CPU查看:jstack

網絡查看:netstat

 

實際問題分析:

線上查看 服務器情況分析 獲取內存dump 獲取javacore

線下分析 工具調試分析內存線程

代碼調試 Eclipse Class Decompiler(自動反編譯,選擇JD-Core,精確行數)

...

轉載請注明:http://lawson.VEVb.com

上面是實際生產問題的自己寫的PPT,copy下來的,JDK自帶的工具和指令比較強大,本篇文章沒有太多介紹。

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产伦精品一区二区三区精品视频| 日韩高清av一区二区三区| 深夜福利国产精品| 日韩成人在线免费观看| 97国产精品视频人人做人人爱| 日韩激情av在线免费观看| 欧美高清电影在线看| 日韩电影中文字幕av| 91美女片黄在线观| 久久精品一偷一偷国产| 中文字幕一区二区三区电影| 裸体女人亚洲精品一区| 成人av在线天堂| 久久久久久久久爱| 日本19禁啪啪免费观看www| 欧美大秀在线观看| 亚洲成avwww人| 精品亚洲夜色av98在线观看| 欧美一级淫片aaaaaaa视频| 日韩精品久久久久久福利| 亚洲最大福利网站| 久久久久国色av免费观看性色| 久久99视频免费| 一区二区福利视频| 日韩视频在线免费| 国产成人短视频| 日韩av成人在线| 亚洲在线免费视频| 97精品欧美一区二区三区| 国产精品极品美女粉嫩高清在线| 亚洲精品国产美女| 久久久久免费精品国产| 欧美成人免费全部观看天天性色| 亚洲精品suv精品一区二区| 日韩一中文字幕| 欧美黑人巨大精品一区二区| 欧美黄色片视频| 91在线观看免费高清完整版在线观看| 日韩精品在线播放| 中文字幕日韩电影| 国产精品高潮粉嫩av| 国产日韩欧美中文| 色琪琪综合男人的天堂aⅴ视频| 91精品久久久久久久久| 97精品国产97久久久久久| 成人黄色av网站| 亚洲日本aⅴ片在线观看香蕉| 国产精品久久久久久av福利软件| 伊是香蕉大人久久| 日本不卡视频在线播放| 亚洲一区亚洲二区| 日韩欧美在线观看视频| 国产精品网站视频| 久久久免费观看视频| 精品丝袜一区二区三区| 日韩有码片在线观看| 欧美国产中文字幕| 亚洲va国产va天堂va久久| 欧美日本高清一区| 色yeye香蕉凹凸一区二区av| 久久免费视频这里只有精品| 亚洲欧美精品一区| 国产伦精品免费视频| 欧美高清性猛交| 日本韩国在线不卡| 91国产在线精品| 欧美性猛交视频| 欧美激情2020午夜免费观看| www.美女亚洲精品| 成人免费黄色网| 91在线观看免费网站| 97超碰色婷婷| 国产精品96久久久久久| 亚洲在线一区二区| 国产精品自拍偷拍视频| 中文字幕亚洲色图| 国产日韩欧美成人| 黑人欧美xxxx| 欧美性理论片在线观看片免费| 26uuu另类亚洲欧美日本老年| 色多多国产成人永久免费网站| 日韩欧美第一页| 日韩毛片在线看| 久久成人在线视频| 亚洲精品第一页| 欧美精品一区二区三区国产精品| 在线电影欧美日韩一区二区私密| xxx欧美精品| 亲子乱一区二区三区电影| 日韩极品精品视频免费观看| 日韩亚洲精品电影| 亚洲最新av在线网站| 欧美色另类天堂2015| 日韩中文字幕第一页| 欧美日韩加勒比精品一区| 97视频人免费观看| 亚洲乱码国产乱码精品精| 精品国偷自产在线视频99| 欧美日韩亚洲激情| 国产精品一区二区三区在线播放| 韩国精品美女www爽爽爽视频| 久久综合久中文字幕青草| 日韩电影免费在线观看中文字幕| 日韩精品福利网站| 永久免费毛片在线播放不卡| 国产欧美精品久久久| 亚洲加勒比久久88色综合| 国产亚洲精品一区二555| 国产亚洲精品一区二区| 欧美大片大片在线播放| 国产成人精品在线| 亚洲美女在线看| 综合欧美国产视频二区| 欧美激情第一页xxx| 欧美高清视频在线播放| 91色在线观看| 最近中文字幕日韩精品| 97视频在线观看免费| 色综合久久悠悠| 亚洲精品久久久久久久久久久| 久久久之久亚州精品露出| 欧美日韩成人免费| 日韩在线播放av| 欧美视频国产精品| 97视频在线观看免费高清完整版在线观看| 国内外成人免费激情在线视频网站| 中文字幕精品—区二区| 亚洲r级在线观看| 国产精品网站入口| 亚洲美女av电影| 国产精品video| 性色av一区二区三区| 亚洲欧美另类人妖| 亚洲人午夜精品免费| 久久噜噜噜精品国产亚洲综合| 亚洲美女在线看| 97香蕉久久超级碰碰高清版| 91深夜福利视频| 亚洲国产日韩欧美在线图片| 国语自产精品视频在线看抢先版图片| 国产欧美日韩视频| 亚洲精品日韩久久久| 久久精品国产亚洲一区二区| 韩国国内大量揄拍精品视频| 久久免费高清视频| 91久久精品久久国产性色也91| 久久久久久18| 91亚洲午夜在线| 亚洲欧美中文日韩在线| 韩国三级电影久久久久久| 欧美日韩加勒比精品一区| 国产欧美日韩丝袜精品一区| 久久91超碰青草是什么| 最好看的2019年中文视频| 日本亚洲精品在线观看| 国产精品精品视频| 国产成人精品久久亚洲高清不卡| 国产成人精品优优av| 国产精品视频白浆免费视频| 国产日韩欧美综合| 亚洲高清一二三区| 欧美激情a∨在线视频播放| 97超级碰碰碰久久久| 国产丝袜精品视频|