高性能ASP.NET站點構建之監測CLR性能
高性能ASP.NET站點構建系列文章目錄
- 高性能ASP.NET站點構建之開篇
- 高性能ASP.NET站點構建之剖析頁面的處理過程
- 高性能ASP.NET站點構建之優化HTTP請求
- 高性能ASP.NET站點構建之細節決定成敗
- 高性能ASP.NET站點構建之性能調優綜述
- 高性能ASP.NET站點構建之識別性能瓶頸
- 高性能ASP.NET站點構建之簡單的優化措施
- ASP.NET站點構建之減少不必要的請求
- 高性能ASP.NET站點構建之托管資源優化
- 高性能ASP.NET站點構建之監測CLR性能
CLR計數器的使用
我們使用系統自帶的性能監測工具來跟蹤和監測垃圾回收器。下面,首先介紹幾個常用的CLR性能監測計數器,我們一般查看.NET CLR Memory分類下的計數器:
Percent Time in GC |
表明了從上次垃圾回收機制運行之后到現在這段時間內,運行垃圾回收機制所花的時間占總時間的百分比。不要超過10%。 |
Gen 0 heap size |
這個數值不是表明當前托管堆中Gen 0對象所占的大小,而是指:還可以分配的Gen 0對象的大小 |
Gen 1 heap size |
表明當前Gen 1 對象所占的托管堆的空間大小 |
Gen 2 heap size |
表明當前Gen 2 對象所占的托管堆的空間大小 |
Large Object Heap size |
當前LOH的大小 |
# Byte in all Heaps |
是上面Gen 0 heap size,Gen 1 heap size,Gen 2 heap size,Large Object Heap size所有的種和,也就是整個托管堆所占的空間大小 |
# Gen 0 Collections |
從系統開啟之后到現在,垃圾回收器回收Gen 0對象的次數 |
# Gen 1 Collections |
從系統開啟之后到現在,垃圾回收器回收Gen 1對象的次數 |
# Gen 2 Collections |
從系統開啟之后到現在,垃圾回收器回收Gen 2對象的次數 |
介紹完上面的一些計數器之后,大家可以運行”perfmon”命令,打開性能監測工具。
下面開始介紹CLR Profiler(CLR 透析器)
CLR Profiler
CLR Profiler是微軟開發的一個工具,這個工具可以用來檢測CLR所占用的內存詳情。
大家可以去下面的鏈接去下載這個工具:
http://www.microsoft.com/downloads/details.aspx?familyid=a362781c-3870-43be-8926-862b40aa0cd0&displaylang=en
下面的鏈接詳細的講述這個工具的用法:
http://msdn.microsoft.com/zh-cn/magazine/ee309515.aspx#MtViewDropDownText
在這里,只是簡單的介紹一下如何使用,至于詳細的操作,還請大家去查看上面給出的鏈接。使用的步驟如下:
1. 運行CLR Proflie
2. 確保”Profiling active, Allocations, Calls”都勾選上。如下:
3. 選擇”File->Profile ASP.NET”.這個操作的背后會停止IIS的運行,然后插入一些指令,然后重啟IIS,所以這個工具在生產環境中慎用。
4. 然后我們可以在VS中F5運行我們的網站(確保在創建網站的時候是以IIS方式來建立站點的,而不是選擇”文件系統”的方式建立)
5. 在界面上面點擊”Kill ASP.NET”.這個操作的背后會移除之前加入到IIS中的一些監視指令。點擊按鈕之后,會出現一些界面。這個界面上面顯示了Gen0, Gen1 Gen2 ,LOH所占的大小,如下:
6. 我們還可以點擊”Histogram”按鈕。這個界面展示了不同大小以及不同類型的對象所占的比例。下面對看出,系統中有很多的string對象,也就說,系統中的string類型的對象占據了系統大部分的內存空間。
原文鏈接:http://www.cnblogs.com/yanyangtian/archive/2011/02/21/1959462.html
【編輯推薦】