WCF 應用程式內置于 .net 4.5,在 Windows Server 2012 R2 資料中心上運行。IIS 8. 客戶端是一個點擊一次的 WPF 應用程式。
該應用程式已運行多年,但開始越來越多地陷入困境,需要應用程式池每天進行一次或兩次回收。我無法找到任何關于究竟出了什么問題的指標。RAM 的峰值為 75%,主要保持在 50% 左右,cpu 運行在 10% 到 20% 之間。當我回收游泳池時,那里沒有什么真正改變。
我的主要線索是該應用程式使用 TCP,當我將本地除錯會話切換到 HTTP 時,它再次快速運行,在 TCP 模式下它很慢。我知道 HTTP 位于 TCP 之上,所以我想知道它是否與握手或其他有關。
TCP 系結看起來像這樣
<binding name="TCPSecured" receiveTimeout="00:05:00" sendTimeout="00:05:00" maxBufferPoolSize="2147483647" maxBufferSize="2147483647" maxReceivedMessageSize="2147483647">
<readerQuotas maxDepth="2147483647" maxStringContentLength="2147483647" maxArrayLength="2147483647" maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647" />
</binding>
HTTP
<binding name="HTTPBindingConfig" receiveTimeout="00:05:00" sendTimeout="00:05:00" maxBufferPoolSize="2147483647" maxBufferSize="2147483647" maxReceivedMessageSize="2147483647">
<security mode="TransportCredentialOnly">
<transport clientCredentialType="Windows" />
</security>
<readerQuotas maxDepth="2147483647" maxStringContentLength="2147483647" maxArrayLength="2147483647" maxBytesPerRead="2147483647" maxNameTableCharCount="2147483647" />
</binding>
使用資源監視器查看 TCP 連接,我看到數十個具有高延遲的,超過 200 個。不知道這意味著什么,或者它是否是新的。
使用性能監視器,我嘗試從 ASP.Net 應用程式、TYCPv4 和 TCP v6 以及其他幾十個應用程式中跟蹤許多選擇,它們都顯示低活動甚至沒有活動。
我對這些東西不知所措,希望人們能提供任何見解。
uj5u.com熱心網友回復:
問題是由于 TCP 埠保持打開狀態。一旦我能夠對其進行監控,就可以找到問題所在。最終使用了 powershell 命令。
檢查一個埠
$established = Get-NetTCPConnection -LocalPort 890 -State Established
$count = $established.Length
echo "OK - $count established connections on port 890 Business"
去看看他們所有人。
$netstat = netstat -aon | Select-String -pattern "TCP "
$processList = Get-Process
foreach ($result in $netstat) {
$splitArray = $result -split " "
$procID = $splitArray[$splitArray.length – 1]
$processName = $processList | Where-Object {$_.id -eq $procID} | select processname
$splitArray[$splitArray.length – 1] = $procID " " $processName.processname
$splitArray -join " "
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/341640.html
