性能測試診斷分析與優(yōu)化.pptx

上傳人:max****ui 文檔編號:15394176 上傳時間:2020-08-09 格式:PPTX 頁數(shù):116 大?。?.04MB
收藏 版權(quán)申訴 舉報 下載
性能測試診斷分析與優(yōu)化.pptx_第1頁
第1頁 / 共116頁
性能測試診斷分析與優(yōu)化.pptx_第2頁
第2頁 / 共116頁
性能測試診斷分析與優(yōu)化.pptx_第3頁
第3頁 / 共116頁

下載文檔到電腦,查找使用更方便

14.9 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《性能測試診斷分析與優(yōu)化.pptx》由會員分享,可在線閱讀,更多相關(guān)《性能測試診斷分析與優(yōu)化.pptx(116頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、性能測試診斷分析與優(yōu)化,陳能技 嘉為IT培訓(xùn)學(xué)院,培訓(xùn)講師介紹,陳能技 () 11年軟件測試與質(zhì)量管理經(jīng)驗 著作: 軟件測試技術(shù)大全 .NET軟件測試實戰(zhàn)技術(shù)大全 QTP自動化測試最佳實踐 軟件自動化測試成功之道 性能測試診斷分析與優(yōu)化,培訓(xùn)課堂的注意事項,培訓(xùn)中 積極、主動不僅使您獲得更多的收獲,也使培訓(xùn)講師能有的放矢、保持激情。 持之以恒、集中精力,您收獲的將不僅是知識; 請您記得將手機調(diào)至震動狀態(tài)或關(guān)機,以免影響您的同學(xué)。 培訓(xùn)后 填寫課程反饋表 刪除桌面臨時文件 關(guān)機,培訓(xùn)后事項,填寫課程反饋表 刪除桌面臨時文件 關(guān)機,性能監(jiān)控方法 性能診斷分析與優(yōu)化 性能測試新興技術(shù)介紹,一、性能監(jiān)

2、控方法,操作系統(tǒng)層性能監(jiān)控 Web服務(wù)器性能監(jiān)控 中間件服務(wù)器性能監(jiān)控,1、操作系統(tǒng)層性能監(jiān)控,CPU性能監(jiān)控 內(nèi)存性能監(jiān)控 磁盤IO性能監(jiān)控 網(wǎng)絡(luò)性能監(jiān)控 開源網(wǎng)絡(luò)性能監(jiān)控工具的應(yīng)用 使用Spotlight監(jiān)控操作系統(tǒng),CPU性能監(jiān)控,查看CPU信息: cat /proc/cpuinfo Top Vmstat 2 3 Dstat -cip 1 Mpstat -P ALL 1 Sar 1 10 Pidstat -p 2 5,Top,使用方式:top - d delay q c S s i n b 說明:即時顯示process的動態(tài) d :改變顯示的更新速度,或是在交談式指令列( interac

3、tive command)按s q :沒有任何延遲的顯示速度,如果使用者是有superuser的權(quán)限,則top將會以最高的優(yōu)先序執(zhí)行 c :切換顯示模式,共有兩種模式,一是只顯示執(zhí)行檔的名稱,另一種是顯示完整的路徑與名稱S :累積模式,會將己完成或消失的子行程( dead child process )的CPU time累積起來 s :安全模式,將交談式指令取消,避免潛在的危機 i :不顯示任何閑置(idle)或無用(zombie)的行程 n :更新的次數(shù),完成后將會退出top b :批次檔模式,搭配n參數(shù)一起使用,可以用來將top的結(jié)果輸出到檔案內(nèi),范例: 顯示更新十次后退出; top -n

4、 10 將更新顯示二次的結(jié)果輸入到名稱為top.log的檔案里: top -n 2 -b top.log,Vmstat,r表示運行隊列的大小 b表示由于IO等待而block的線程數(shù)量 in表示中斷的數(shù)量 cs表示上下文切換的數(shù)量 us表示用戶CPU時間 sys表示系統(tǒng)CPU時間 wa表示由于IO等待而是CPU處于idle狀態(tài)的時間 id表示CPU處于idle狀態(tài)的總時間,DSTAT,dstat可以給出每一個設(shè)備產(chǎn)生的中斷數(shù) 設(shè)備名和設(shè)備號的關(guān)系可以參考文件 /proc/interrupts,Mpstat,mpstat可以顯示每個CPU的運行狀況,比如系統(tǒng)有4個CPU。我們可以看到: # mps

5、tat P ALL 1 Linux 2.4.21-20.ELsmp (localhost.localdomain) 05/23/2006 05:17:31 PM CPU %user %nice %system %idle intr/s 05:17:32 PM all 0.00 0.00 3.19 96.53 13.27 05:17:32 PM 0 0.00 0.00 0.00 100.00 0.00 05:17:32 PM 1 1.12 0.00 12.73 86.15 13.27 05:17:32 PM 2 0.00 0.00 0.00 100.00 0.00 05:17:32 PM 3 0

6、.00 0.00 0.00 100.00 0.00,sar,%user列顯示了用戶進程消耗的CPU時間百分比。 %nice列顯示了運行正常進程所消耗的CPU時間百分比。 %system列顯示了系統(tǒng)進程消耗的CPU時間百分比。 %iowait列顯示了IO等待所占用的CPU時間百分比 %steal列顯示了在內(nèi)存相對緊張的環(huán)境下pagein強制對不同的頁面進行的steal操作。 %idle列顯示了CPU處在空閑狀態(tài)的時間百分比。 sar 2 5 // 每隔2秒,顯示5次,CPU使用的情況 sar支持保存成兩種格式的文件,一種是文本文件,一種是二進制文件(只有通過sar自己的命令才能查看) sar 1

7、 10 data.txt sar 1 5 - o data // 每隔1秒,寫入5次,將CPU使用的數(shù)據(jù)寫入二進制文件data中。 sar - f data // 查看data文件,Pidstat,監(jiān)視某個進程的CPU使用情況 1.通過ps命令找到相應(yīng)進程的PID: ps - e 2.使用pidstat命令監(jiān)視進程,詳細用法見:http://pagesperso-orange.fr/sebastien.godard/man_pidstat.html pidstat 2 5 每隔2秒,顯示5次,所有活動進程的CPU 使用情況 pidstat - p 3132 2 5 每隔2秒,顯示5次,PID為

8、1643的進程的CPU使用情況顯示 pidstat - p 3132 2 5 - r 每隔2秒,顯示5次,PID為1643的進程的內(nèi)存使用情況顯示,內(nèi)存性能監(jiān)控,查看內(nèi)存信息: cat /proc/meminfo Free m Vmstat 2 10 Top Ps,free,$ free -m total used free shared buffers cached Mem: 1002 769 232 0 62 421 -/+ buffers/cache: 286 715 Swap: 1153 0 1153,第一部分Mem行: total 內(nèi)存總數(shù): 1002M

9、used 已經(jīng)使用的內(nèi)存數(shù): 769M free 空閑的內(nèi)存數(shù): 232M shared 當(dāng)前已經(jīng)廢棄不用,總是0 buffers Buffer緩存內(nèi)存數(shù): 62M cached Page緩存內(nèi)存數(shù):421M 關(guān)系:total(1002M) = used(769M) + free(232M),第二部分(-/+ buffers/cache): (-buffers/cache) used內(nèi)存數(shù):286M (指的第一部分Mem行中的used - buffers - cached) (+buffers/cache) free內(nèi)存數(shù): 715M (指的第一部分Mem行中的free + buffers +

10、 cached) 可見-buffers/cache反映的是被程序?qū)崒嵲谠诔缘舻膬?nèi)存,而+buffers/cache反映的是可以挪用的內(nèi)存總數(shù)。,vmstat,,vmstat,memory swpd列表示切換到內(nèi)存交換區(qū)的內(nèi)存數(shù)量(以k為單位)。如果swpd的值不為0,或者比較大,只要si、so的值長期為0,這種情況下一般不用擔(dān)心,不會影響系統(tǒng)性能。 free列表示當(dāng)前空閑的物理內(nèi)存數(shù)量(以k為單位) buff列表示buffers cache的內(nèi)存數(shù)量,一般對塊設(shè)備的讀寫才需要緩沖。 cache列表示page cached的內(nèi)存數(shù)量,一般作為文件系統(tǒng)cached,頻繁訪問的文件都會被cached

11、,如果cache值較大,說明cached的文件數(shù)較多,如果此時IO中bi比較小,說明文件系統(tǒng)效率比較好。 swap si 列表示由磁盤調(diào)入內(nèi)存,也就是內(nèi)存進入內(nèi)存交換區(qū)的數(shù)量。 so列表示由內(nèi)存調(diào)入磁盤,也就是內(nèi)存交換區(qū)進入內(nèi)存的數(shù)量。 一般情況下,si、so的值都為0,如果si、so的值長期不為0,則表示系統(tǒng)內(nèi)存不足。需要增加系統(tǒng)內(nèi)存。,監(jiān)控單個進程占用內(nèi)存的情況,top -d 1然后shift + m(Sort by memory usage) Ps aux | grep HoldMemoryMain top -b -n1 -p 21642 | tail -2|head -1|awk pr

12、int $5 VIRT=SWAP+RES VIRT 進程使用的虛擬內(nèi)存總量,單位kb SWAP 進程使用的虛擬內(nèi)存中,被換出的大小,單位kb RES 進程使用的、未被換出的物理內(nèi)存大小,單位kb,磁盤性能監(jiān)控,df -hlT parted -l Vmstat iostat -d 2 3 sar -d 2 3 Iotop pidstat iodump,iostat,,iotop,pidstat,pidstat -d 1 pidstat -C test_io -t -d 1,iodump,wget echo 1 /proc/sys/vm/block_dump,rootkanga:# while t

13、rue; do sleep 1; dmesg -c; done | perl iodump C# Caught SIGINT. TASK PID TOTAL READ WRITE DIRTY DEVICES firefox 4450 4538 251 4287 0 sda4, sda3 kjournald 2100 551 0 551 0 sda4 firefox 28452 185 185 0 0 sda4 kjournald 782 59 0 59 0 sda3 pdflush 31 30

14、 0 30 0 sda4, sda3 syslogd 2485 2 0 2 0 sda3 firefox 28414 2 2 0 0 sda4, sda3 firefox 28413 1 1 0 0 sda4 firefox 28410 1 1 0 0 sda4 firefox 28307 1 1 0 0 sda4 firefox 28451 1 1 0 0 sda4,網(wǎng)絡(luò)性能監(jiān)控,ping Netstat -i Sar -n DEV 1 3 Sar

15、-n SOCK 1 3 ifTop、ipTraf,ifTop,,開源性能監(jiān)控工具的應(yīng)用,Cacti、Nagios Nmon ,Cacti,Cacti是一套基于PHP,MySQL,SNMP及 RRDTool開發(fā)的監(jiān)控工具,可以監(jiān)控主機的狀態(tài)和負載情況,添加相應(yīng)的模板后,可以用來監(jiān)控 Apache、MySQL 等服務(wù)器的運行狀態(tài)。,Nmon,Nmon是IBM提供的開源監(jiān)控工具,可對AIX和Linux系統(tǒng)資源進行監(jiān)控,可收集系統(tǒng)資源使用情況并輸出到特定文件,并可利用Excel分析工具進行數(shù)據(jù)統(tǒng)計分析。,使用Spotlight監(jiān)控操作系統(tǒng),,2、Web服務(wù)器性能監(jiān)控,IHS性能監(jiān)控方法 HTTP連接狀

16、態(tài)監(jiān)控 Web服務(wù)器吞吐量監(jiān)控,IHS性能監(jiān)控,打開server-status監(jiān)控 狀態(tài)監(jiān)控頁面,打開server-status監(jiān)控,LoadModule status_module modules/ApacheModuleStatus.dll # Allow server status reports, with the URL of http://servername/server-status # Change the .your_ to match your domain to enable. SetHandler server-status order deny,allow deny

17、 from all allow from 127.0.0.1 ,狀態(tài)監(jiān)控頁面,Scoreboard Key: _ Waiting for Connection, S Starting up, R Reading Request, W Sending Reply, K Keepalive (read), D DNS Lookup, L Logging, G Gracefully finishing, . Open slot with no current process,Web服務(wù)器網(wǎng)絡(luò)連接監(jiān)控,Linux下實時檢測httpd連接數(shù) watch -n 1 -d pgrep httpd|wc -l

18、“ 查看TCP并發(fā)連接情況: netstat -n | awk /tcp/ ++S$NF END for(a in S) print a, Sa,Web服務(wù)器網(wǎng)絡(luò)連接監(jiān)控,3、中間件服務(wù)器性能監(jiān)控,WAS性能監(jiān)控 WAS自帶監(jiān)控工具的使用 perfServletApp的使用方法 LoadRunner監(jiān)控WAS 使用AppDynamics監(jiān)控WebSphere JVM性能監(jiān)控方法及工具 GC日志監(jiān)控分析 Thread Dump JVM遠程監(jiān)控 JDBC性能監(jiān)控,WAS性能漏斗模型,WAS性能監(jiān)控的方面,Session 線程池 JDBC連接 JVM性能,WAS性能監(jiān)控的方法和工具,WAS自帶性能監(jiān)

19、控工具的使用 perfServletApp的使用方法 LoadRunner監(jiān)控WAS,WAS自帶性能監(jiān)控工具的使用,WAS自帶性能監(jiān)控工具的使用,用TPV監(jiān)控JVM發(fā)現(xiàn)內(nèi)存泄漏現(xiàn)象,perfServletApp的使用方法,部署PerfServletApp.ear到WebSphere目錄下,perfServletApp的使用方法,LoadRunner監(jiān)控WAS,JVM性能監(jiān)控通用方法,JConsole實時監(jiān)控JVM GC日志分析 Heap Dump Thread Dump,JVM性能監(jiān)控通用方法-JConsole實時監(jiān)控JVM,JVM性能監(jiān)控通用方法-GC日志分析,打開 WAS GC日志,打開W

20、AS GC日志 Java和進程管理-進程定義-Java虛擬機-詳細垃圾回收(保存配置后重新啟動服務(wù)生效) Java和進程管理-進程定義-Java虛擬機-運行時-詳細垃圾回收(確認后立即生效) 在通用JVM參數(shù)輸入框中添加:-Xverbosegclog:gc.log JVM GC日志的保存目錄 WASHOME/profiles/yourprofile/logs/yourserver/native_stderr.log 和 native_stdout.log C:WebSphereAppServerprofilesAppSrv01gc.log,GC日志分析工具,IBM Support Assist

21、ant - Garbage Collection and Memory Visualizer IBM Pattern Modeling and Analysis Tool(PMAT) GCViewer ,JVM性能監(jiān)控通用方法- Heap Dump,heapdump文件是一個二進制文件,它保存了某一時刻jvm堆中對象情況,這種文件需要相應(yīng)的工具進行分析,例如 heapanalyzer。這個文件最重要的作用就是分析系統(tǒng)是否存在內(nèi)存溢出的情況,通過heapanalyzer可以很簡單地分析出溢出的位置。 產(chǎn)生WAS Heap Dump的方法,JVM性能監(jiān)控通用方法-Thread Dump,線程監(jiān)控和

22、分析工具,Thread dump提供了當(dāng)前活動的線程的快照.它提供了JVM中所有Java線程的棧跟蹤信息 產(chǎn)生WAS Thread Dump的方法 Jconsole VisualVM JProfiler Thread Dump Analyzer IBM Thread and Monitor Dump Analyzer for Java,JVM遠程監(jiān)控,Jstatd Jconsolevisualvm Jprofile,中間件性能監(jiān)控與分析工具,HP Diagnostics JProfiler JProbe YourKit AppDynamics DomainHealth Javamelody J

23、AMON,AppDynamics,WAS的Session監(jiān)控與分析,ActiveCount:正在處理請求的Session數(shù)量 LiveCount:目前緩存在內(nèi)存中的本地Session的數(shù)量,WAS線程數(shù)監(jiān)控分析,ActiveCount: 處于激活狀態(tài)的線程數(shù)。 PoolSize: 線程池中的平均線程數(shù)。 PercentMaxed: 所有線程在使用的時間的平均百分比。 DeclaredthreadHungCount: 掛起的線程數(shù)。,WAS的JDBC連接池監(jiān)控,WaitingThreadCount: 當(dāng)前等待連接的線程。 FaultCount: 在連接池中出現(xiàn)錯誤(例如超時)的數(shù)量。 Perce

24、ntUsed: 當(dāng)前連接池中被使用的平均百分比。,JDBC性能分析,P6spy + sqlprofiler JDbMonitor JAMON,JProfiler監(jiān)控JDBC,,二、性能診斷分析與優(yōu)化,操作系統(tǒng)層性能分析與優(yōu)化 HIS服務(wù)器配置優(yōu)化 中間件性能分析與優(yōu)化 JVM性能分析 使用JConsoleJava VisualVM監(jiān)控和分析WebSphere的JVM性能 JVM參數(shù)調(diào)整與優(yōu)化 利用JProfiler分析定位Java內(nèi)存泄漏問題 Java代碼線程死鎖問題分析與定位 JSPServlet性能優(yōu)化方法,操作系統(tǒng)層性能分析與優(yōu)化,Linux系統(tǒng)性能診斷 操作系統(tǒng)性能調(diào)優(yōu),Linux系統(tǒng)

25、性能診斷,CPU,對于每一個CPU來說運行隊列不要超過3,例如,如果是雙核CPU就不要超過6; 如果CPU在滿負荷運行,應(yīng)該符合下列分布, a) User Time:65%70% b) System Time:30%35% c) Idle:0%5% 對于上下文切換要結(jié)合CPU使用率來看,如果CPU使用滿足上述分布,大量的上下文切換也是可以接受的。,內(nèi)存,(-/+ buffers/cache)的free和used Swap(si 、so),內(nèi)存分析案例,上面是一個頻繁讀寫交換區(qū)的例子,可以觀察到以下幾點: 物理可用內(nèi)存 free 基本沒什么顯著變化,swapd 逐步增加 當(dāng)臟頁達到10的時候就開

26、始大量使用 swap,free目前的值約等于256MB*10%=2.56MB buff 穩(wěn)步減少說明系統(tǒng)知道內(nèi)存不夠了,kwapd 正在從 buff 那里借用部分內(nèi)存 kswapd 持續(xù)把臟頁面寫到 swap 交換區(qū)(so),從 swapd 逐漸增加看出確實如此,IO,同一時間進行大量的I/O操作 在這種情況時我們會發(fā)現(xiàn)CPU的wa時間百分比會上升,證明系統(tǒng)的idle時間大部分都是在等待I/O操作。,從這個輸出我們可以看到CPU有50%的時間都在等待I/O操作,我們還可以看到系統(tǒng)的bi值很大,證明系統(tǒng)有大量的I/O請求將磁盤內(nèi)容讀入內(nèi)存。,IO,將top的輸出通過faults進行排序。我們可以

27、看到vmware產(chǎn)生最多的page faults。也就是說它進行了大量的IO操作。,IO,任何I/O操作都需要一定的時間,而且這些時間對于硬盤來說是確定的,它包含磁盤旋轉(zhuǎn)的延時RD(rotation delay)和磁頭搜索時間DS(disk seek)。 RD由磁盤轉(zhuǎn)速(RPM)決定。RD是磁盤旋轉(zhuǎn)一周所需時間的一半。如RPM為10000(1分鐘轉(zhuǎn)1萬次). RPS=RPM/60=166(1秒轉(zhuǎn)166次)。1/166=0.0006=6ms (磁盤旋轉(zhuǎn)一周要6毫秒)。RD=6ms/2=3ms 磁盤平均搜索時間是3ms,數(shù)據(jù)傳輸?shù)钠骄訒r是2ms,這樣一次I/O操作的平均時間是:3ms+3ms+2

28、ms=8ms IOPS=1000/8=125 這塊磁盤的每秒IO數(shù)(IOPS)為125。所以對于10000RPM的磁盤來說它所能承受的IO操作在IOPS在120150之間。如果系統(tǒng)的I/O請求超過這個值,就會使磁盤成為系統(tǒng)的瓶頸。,連續(xù)I/O vs.隨機I/O,連續(xù)I/O常常出現(xiàn)在企業(yè)級數(shù)據(jù)庫這樣的應(yīng)用中,需要連續(xù)的讀取大量數(shù)據(jù)。這種系統(tǒng)的性能依靠它讀取和移動數(shù)據(jù)的大小和快慢。我們用iostat來監(jiān)控,會發(fā)現(xiàn)rKB/s和wKB/s會很高。,Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz a

29、wait svctm %util /dev/sda 0.00 12891.43 0.00 105.71 0.00 106080.00 0.00 53040.00 1003.46 1099.43 3442.43 26.49 280.00,從輸出我們看到w/s=105,wKB/s=53040.所以53040/105=505KB per I/O.,連續(xù)I/O vs.隨機I/O,對于隨機I/O的系統(tǒng)來說性能的關(guān)注點不在搜傳輸數(shù)據(jù)的大小和速度,而是在磁盤的IOPS。這類系統(tǒng)的I/O請求比較小但是數(shù)量很大,如Web服務(wù)器和Mail服務(wù)器。他們的性能主要依賴每秒鐘可處理的請求數(shù):,Device: rrqm/

30、s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util /dev/sda 0.00 633.67 3.06 102.31 24.49 5281.63 12.24 2640.82 288.89 73.67 113.89 27.22 50.00,從輸出我們看到w/s=102,wKB/s=2640.所以2640/102=23KB per I/O. 因此對于連續(xù)I/O系統(tǒng)來說我們要關(guān)注系統(tǒng)讀取大量數(shù)據(jù)的能力即KB per request. 對于隨機I/O系統(tǒng)我們注重IOPS值.,操作系統(tǒng)性能調(diào)優(yōu),系

31、統(tǒng)安裝優(yōu)化 RAID SWAP分區(qū) 系統(tǒng)安裝后的初步調(diào)整優(yōu)化 檢查系統(tǒng)是否正常 關(guān)閉不需要的服務(wù) 對TCP/IP網(wǎng)絡(luò)參數(shù)進行調(diào)整 內(nèi)核參數(shù)優(yōu)化 針對Web服務(wù)器的網(wǎng)絡(luò)參數(shù)優(yōu)化 針對數(shù)據(jù)庫服務(wù)器的內(nèi)核參數(shù)優(yōu)化,IHS服務(wù)器配置優(yōu)化,MPM對Apache性能的影響 影響性能的配置 并發(fā)線程相關(guān)的設(shè)置 日志對性能的影響 壓縮 mod_cache,中間件性能分析與優(yōu)化,IHS優(yōu)化 WAS Session優(yōu)化 內(nèi)存中最大會話量 Session超時 WAS線程池優(yōu)化 WAS JDBC連接池優(yōu)化 連接超時 最大連接數(shù) 最小連接數(shù) JVM性能分析與優(yōu)化,,應(yīng)用層攻擊,數(shù)據(jù)庫服務(wù)器,JDBC數(shù)據(jù)庫連接典型問題分

32、析,某電網(wǎng)公司企業(yè)網(wǎng)站標準化系統(tǒng),在100個并發(fā)用戶壓力下進行內(nèi)網(wǎng)網(wǎng)站首頁訪問登錄操作,發(fā)現(xiàn)該系統(tǒng)的應(yīng)用服務(wù)器和數(shù)據(jù)庫服務(wù)器連接異常,大量出現(xiàn)錯誤,測試軟件報錯信息如下:,通過對分析,發(fā)現(xiàn)部分連接參數(shù)設(shè)置太小,對連接參數(shù)進行調(diào)整后,測試組對系統(tǒng)進行了再次測試,基本不存在連接失敗的情況。,,應(yīng)用層攻擊,某電網(wǎng)公司人力資源系統(tǒng),員工名冊查詢無法做壓力測試,響應(yīng)超時的問題,主要是請求的sql太長了,com.sophia.hr.modules.employee.external.impl.EmployeeServiceImpl.java類,修改了方法empListSQL4Info方法,再次測試,響應(yīng)時

33、間明顯改善。,JDBC數(shù)據(jù)庫連接典型問題分析,,應(yīng)用層攻擊,某電商網(wǎng)站,JDBC數(shù)據(jù)庫連接典型問題分析,Caused by: java.sql.SQLException: We are already in the process of making 11 connections and the number of simultaneous builds has been throttled to 10,JVM性能分析,JVM垃圾回收對性能的影響 吞吐量、GC停頓 JVM內(nèi)存泄漏診斷 線程問題診斷 JVM堆大小對垃圾回收、系統(tǒng)吞吐量的影響 GC策略對系統(tǒng)性能的影響,JVM的堆,JVM年輕代與年

34、老代,Minor GC的過程,Full GC,Full GC對性能的影響 jstat -gc pid 可以顯示gc的信息,查看gc的次數(shù),及時間。 其中最后五項,分別是young gc的次數(shù),young gc的時間,full gc的次數(shù),full gc的時間,gc的總時間。,GC日志人肉分析,WAS GC日志分析工具,用PMAT分析GC日志 java -Xmx512m -jar ga414.jar GCViewer,WAS GC 日志分析 案例,WAS GC 日志分析 案例,可以看到Full GC非常多,占所有pause時間比達到65.9%,這是有問題的,GC應(yīng)該盡可能在年輕代完成,而不是到年

35、老代,JVM堆大小對垃圾回收、系統(tǒng)吞吐量的影響,案例 - PlantsByWebSphere JConsole遠程監(jiān)控WAS JProfiler查看GC Activity(垃圾回收器的活動占用整體時間的百分比),案例,某電網(wǎng)公司可靠性系統(tǒng) JVM內(nèi)存不足、頻繁GC、服務(wù)器CPU忙,JVM參數(shù)調(diào)整與優(yōu)化,JVM堆參數(shù)設(shè)置 GC參數(shù)設(shè)置,GC策略對系統(tǒng)性能的影響,新生代串行收集器 老年代串行收集器 并行收集器 新生代并行回收收集器 老年代并行回收收集器 CMS(Concurrent Mark Sweep)收集器,-Xgcpolicy:optthruput -Xgcpolicy:optavgpaus

36、e -Xgcpolicy:gencon -Xgcpolicy:balanced,案例 PlantsByWebSphere,Java代碼性能問題診斷分析與優(yōu)化,Java代碼性能分析 JSPServlet性能分析與優(yōu)化 JDBC性能分析與優(yōu)化 JProfiler等性能分析工具的應(yīng)用,Java代碼性能分析,代碼執(zhí)行效率 CPU使用 內(nèi)存使用 IO使用 線程鎖,JAVA代碼執(zhí)行效率監(jiān)控分析,JAVA CPU使用監(jiān)控分析,查看java進程: jps 確認java進程CPU性能: pidstat -p -u 1 3 進一步查看線程CPU性能,定位到CPU高消耗的線程ID: pidstat -p 1 3

37、 -u -t 根據(jù)定位到的線程ID,使用jstack導(dǎo)出線程堆棧進行驗證: jstack -l /tmp/t.txt 在導(dǎo)出的線程堆棧中查找引起高CPU消耗的線程ID(nid),需要從十六進制轉(zhuǎn)換為10進制,從而定位到哪個線程的Java代碼執(zhí)行導(dǎo)致占用大量CPU,JAVA內(nèi)存使用監(jiān)控分析,JProfiler性能分析工具的應(yīng)用,案例演練-Java內(nèi)存泄漏檢測,TestMem,JAVA I/O使用監(jiān)控分析,iostat -dx 3 jps pidstat -p -d -t 1 3 jstack -l /tmp/t.txt,Java線程鎖監(jiān)控分析,Jstack監(jiān)控JAVA線程死鎖,jps jst

38、ack -l 1.txt 查找輸出結(jié)果定位死鎖,WAS線程Dump,Linux下命令行啟動WAS, Kill -3 /opt/IBM/WebSphere/AppServer/profiles/AppSrv01,Idle線程:一個已經(jīng)準備好接受請求的線程,但是沒有和插件或者客戶端建立連接 Keep-Alive線程:是一個已經(jīng)準備好接受請求的線程,并且已經(jīng)和插件或者客戶端建立連接 正在接受請求的線程:是一個線程正在讀取request的內(nèi)容或者頭部,WAS線程Dump分析工具,IBM Thread and Monitor Dump Analyzer for Java java -Xmx500m -j

39、ar jca101.jar,JSPServlet性能分析與優(yōu)化,JSP 、Servlet常見性能問題分析與優(yōu)化 工具 AppDynamics、JProfiler JAMON,JSP 、Servlet常見性能問題分析與優(yōu)化,頁面包含 Page Session JavaBean的生命周期 Session過期時間 init()方法與緩存 壓縮輸出,三、性能測試新興技術(shù)介紹,開源性能壓力測試工具介紹 云性能測試服務(wù)介紹 端到端性能測試與性能監(jiān)控方案,開源性能壓力測試工具介紹,早期:Jmeter、The Grinder Tsung Gatling,Tsung,http://tsung.erlang-pr

40、ojects.org/ Jabber/XMPP協(xié)議90萬并發(fā)jabber用戶(使用4個節(jié)點的tsung 集群)(3xSun V240 + 1 Sun V440)10萬并發(fā)用戶(使用3個結(jié)點tsung集群)(CPU 800MHz) HTTP and HTTPS協(xié)議12萬并發(fā)用戶(使用4個結(jié)點的tsung集群)該測試平臺達到每秒3000個請求1000萬并發(fā)用戶,(使用75結(jié)點的tsung集群,)并發(fā)超過100萬個請求 目前可以用來測試HTTP,WebDAV,SOAP,PostgreSQL, MySQL, LDAP, and Jabber/XMPP,Gatling,Gatling是一款基于Scala

41、 開發(fā)的高性能服務(wù)器性能測試工具,它主要用于對服務(wù)器進行負載等測試,并分析和測量服務(wù)器的各種性能指標。Gatling主要用于測量基于HTTP的服務(wù)器,比如Web應(yīng)用程序,RESTful服務(wù)等,除此之外它擁有以下特點: 支持Akka Actors 和 Async IO,從而能達到很高的性能 支持實時生成Html動態(tài)輕量報表,從而使報表更易閱讀和進行數(shù)據(jù)分析 支持DSL腳本,從而使測試腳本更易開發(fā)與維護 支持錄制并生成測試腳本,從而可以方便的生成測試腳本 支持導(dǎo)入HAR(Http Archive)并生成測試腳本 支持Maven,Eclipse,IntelliJ等,以便于開發(fā) 支持Jenkins,以便于進行持續(xù)集成 支持插件,從而可以擴展其功能,比如可以擴展對其他協(xié)議的支持,云性能測試,SOASTA Gomez,NeoLoad的云測試方案,,端到端性能測試與性能監(jiān)控方案,培訓(xùn)后事項,填寫課程反饋表 刪除桌面臨時文件 關(guān)機,陳能技,

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!