WCF性能計(jì)數(shù)器應(yīng)用特點(diǎn)介紹
WCF開發(fā)工具功能強(qiáng)大,其中包含有許多功能特點(diǎn),值得我們?nèi)ド钊胙芯?。其中就包括我們今天為大家介紹的WCF性能計(jì)數(shù)器。在這篇文章中,大家將會通過各種示例來詳細(xì)了解一下WCF性能計(jì)數(shù)器的應(yīng)用方式。
啟用WCF性能計(jì)數(shù)器
您可以通過 WCF 服務(wù)的 app.config 配置文件啟用 WCF 服務(wù)的性能計(jì)數(shù)器,如下所示:
- < configuration>
 - < system.serviceModel>
 - < diagnostics performanceCounters="All" />
 - < /system.serviceModel>
 - < /configuration>
 
可以將 performanceCounters 屬性設(shè)置為啟用特定類型的性能計(jì)數(shù)器。有效值為
All:啟用所有類別計(jì)數(shù)器(ServiceModelService、ServiceModelEndpoint 和 ServiceModelOperation)。
ServiceOnly:僅啟用 ServiceModelService 類別計(jì)數(shù)器。
Off:禁用 ServiceModel* 性能計(jì)數(shù)器。這是默認(rèn)值。
如果要啟用所有 WCF 應(yīng)用程序的性能計(jì)數(shù)器,則可以將配置設(shè)置放置到 Machine.config 文件中。有關(guān)在計(jì)算機(jī)上為性能計(jì)數(shù)器配置足夠內(nèi)存的更多信息,請參見“增加性能計(jì)數(shù)器的內(nèi)存大小”(可能為英文網(wǎng)頁)一節(jié)。
還可以在代碼中啟用WCF性能計(jì)數(shù)器,如下所示:
- using System.Configuration;
 - using System.ServiceModel.Configuration;
 - using System.ServiceModel.Diagnostics;
 - Configuration config = ConfigurationManager.OpenExeConfiguration(
 - ConfigurationUserLevel.None);
 - ServiceModelSectionGroup sg = ServiceModelSectionGroup.
 
GetSectionGroup(config);- sg.Diagnostic.PerformanceCounters = PerformanceCounterScope.All;
 - config.Save();
 
查看性能數(shù)據(jù)#t#
若要查看性能計(jì)數(shù)器捕獲的數(shù)據(jù),則可以使用 Windows 附帶的性能監(jiān)視器 (Perfmon.exe)。通過轉(zhuǎn)到“開始”,單擊“運(yùn)行”并在對話框中鍵入 perfmon.exe 以啟動該工具。
注意:
WCF性能計(jì)數(shù)器實(shí)例可能會在終結(jié)點(diǎn)調(diào)度程序處理最后一條消息之前被釋放。這可能導(dǎo)致不能為某些消息捕獲性能數(shù)據(jù)。
增加性能計(jì)數(shù)器的內(nèi)存大小
WCF 為其性能計(jì)數(shù)器類別使用單獨(dú)的共享內(nèi)存。
默認(rèn)情況下,單獨(dú)的共享內(nèi)存被設(shè)置為全局性能計(jì)數(shù)器內(nèi)存大小的四分之一。默認(rèn)的全局性能計(jì)數(shù)器內(nèi)存大小為 524,288 字節(jié)。因此,三個(gè) WCF 性能計(jì)數(shù)器類別默認(rèn)分別具有約 128KB 的內(nèi)存大小。根據(jù)計(jì)算機(jī)上 WCF 應(yīng)用程序的運(yùn)行時(shí)特性,性能計(jì)數(shù)器內(nèi)存可能會用盡。發(fā)生這種情況時(shí),WCF 會向應(yīng)用程序事件日志中寫入一個(gè)錯(cuò)誤。該錯(cuò)誤的內(nèi)容聲明未加載性能計(jì)數(shù)器,并聲明一個(gè)包含異常“System.InvalidOperationException:可用于自定義計(jì)數(shù)器文件視圖的內(nèi)存不足。”的項(xiàng)。如果在錯(cuò)誤級別啟用了跟蹤,此故障也將被跟蹤。如果性能計(jì)數(shù)器內(nèi)存已用盡,在啟用性能計(jì)數(shù)器的情況下繼續(xù)運(yùn)行您的 WCF 應(yīng)用程序可能會導(dǎo)致性能明顯下降。如果您是計(jì)算機(jī)管理員,則應(yīng)對計(jì)算機(jī)進(jìn)行配置,以便分配足夠的內(nèi)存來支持隨時(shí)可能存在的最大數(shù)量的性能計(jì)數(shù)器。有關(guān)更多信息,請參見 performanceCounters(可能為英文網(wǎng)頁)。
可以在注冊表中更改 WCF 類別的性能計(jì)數(shù)器的內(nèi)存量。為此,需要向以下三個(gè)位置添加名為 FileMappingSize 的新 DWORD 值,并將它設(shè)為所需的值(以字節(jié)為單位)。重新啟動您的計(jì)算機(jī)以使這些更改生效。
HKLM\System\CurrentControlSet\Services\ServiceModelEndpoint 3.0.0.0\Performance
HKLM\System\CurrentControlSet\Services\ServiceModelOperation 3.0.0.0\Performance
HKLM\System\CurrentControlSet\Services\ServiceModelService 3.0.0.0\Performance
當(dāng)釋放的大量對象(例如 ServiceHost)等待進(jìn)行垃圾回收時(shí),PrivateBytes 性能計(jì)數(shù)器將記錄一個(gè)非常大的數(shù)字。若要解決此問題,可以添加特定于自己的應(yīng)用程序的計(jì)數(shù)器,或使用 performanceCounters 屬性僅啟用服務(wù)級別計(jì)數(shù)器。
WCF性能計(jì)數(shù)器的類型
性能計(jì)數(shù)器可分為三個(gè)不同級別:服務(wù)、終結(jié)點(diǎn)和操作。
可以使用 WMI 檢索性能計(jì)數(shù)器實(shí)例的名稱。例如,
通過 WMI Service實(shí)例的“CounterInstanceName”屬性可獲得服務(wù)計(jì)數(shù)器實(shí)例的名稱。
通過 WMI 終結(jié)點(diǎn)實(shí)例的“CounterInstanceName”屬性可獲得終結(jié)點(diǎn)計(jì)數(shù)器實(shí)例的名稱。
通過 WMI 終結(jié)點(diǎn)實(shí)例的“GetOperationCounterInstanceName”方法可獲得操作計(jì)數(shù)器實(shí)例的名稱。
有關(guān) WMI 的更多信息,請參見使用 Windows Management Instrumentation 進(jìn)行診斷。
服務(wù)WCF性能計(jì)數(shù)器
服務(wù)性能計(jì)數(shù)器將服務(wù)行為作為整體來進(jìn)行衡量,可用于診斷服務(wù)整體性能。如果使用性能監(jiān)視器查看,可以在 ServiceModelService 3.0.0.0 性能對象下找到服務(wù)性能計(jì)數(shù)器。使用以下模式命名計(jì)數(shù)器實(shí)例:
ServiceName@ServiceBaseAddress服務(wù)范圍內(nèi)的計(jì)數(shù)器是從終結(jié)點(diǎn)集合中的計(jì)數(shù)器聚合來的。
創(chuàng)建新的 InstanceContext 時(shí),用于創(chuàng)建服務(wù)實(shí)例的性能計(jì)數(shù)器將遞增。請注意,即使在(通過現(xiàn)有服務(wù))收到非激活消息時(shí),或在從一個(gè)會話連接到實(shí)例、結(jié)束會話然后從其他會話重新進(jìn)行連接時(shí),也將創(chuàng)建新的 InstanceContext。
終結(jié)點(diǎn)性能計(jì)數(shù)器使用終結(jié)點(diǎn)性能計(jì)數(shù)器可以查看反映終結(jié)點(diǎn)如何接受消息的數(shù)據(jù)。使用性能監(jiān)視器查看時(shí),可在 ServiceModelEndpoint 3.0.0.0 性能對象下找到終結(jié)點(diǎn)性能計(jì)數(shù)器。使用以下模式命名計(jì)數(shù)器實(shí)例:
(ServiceName).(ContractName)@(endpoint listener address)數(shù)據(jù)與為單個(gè)操作收集的數(shù)據(jù)類似,但它只在終結(jié)點(diǎn)之間聚合。
終結(jié)點(diǎn)范圍內(nèi)的計(jì)數(shù)器是從操作集合中的計(jì)數(shù)器聚合來的。
注意:
如果兩個(gè)終結(jié)點(diǎn)具有相同的協(xié)定名稱和地址,它們將映射到同一個(gè)計(jì)數(shù)器實(shí)例中。
操作WCF性能計(jì)數(shù)器
如果使用性能監(jiān)視器查看,可以在 ServiceModelOperation 3.0.0.0 性能對象下找到操作性能計(jì)數(shù)器。每個(gè)操作都有一個(gè)單獨(dú)的實(shí)例。也就是說,如果給定的協(xié)定具有 10 個(gè)操作,則有 10 個(gè)操作計(jì)數(shù)器實(shí)例與該協(xié)定相關(guān)聯(lián)。對象實(shí)例按下面的模式命名:
(ServiceName).(ContractName).(OperationName)@(first endpoint listener address)使用此計(jì)數(shù)器可以衡量調(diào)用的使用方式以及操作的執(zhí)行情況。
當(dāng)計(jì)數(shù)器在多個(gè)范圍內(nèi)可見時(shí),從范圍的較高一級收集到的數(shù)據(jù)會與從范圍的較低一級收集到的數(shù)據(jù)相聚合。例如,終結(jié)點(diǎn)處的 Calls 表示終結(jié)點(diǎn)內(nèi)所有操作調(diào)用的總和;服務(wù)處的 Calls 表示對服務(wù)內(nèi)所有終結(jié)點(diǎn)的所有調(diào)用的總和。
注意:
如果一個(gè)協(xié)定上有兩個(gè)操作名稱,則只能為這兩個(gè)操作獲取一個(gè)計(jì)數(shù)器實(shí)例。















 
 
 


 
 
 
 