真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用DebugDiagnosticTool排除內存泄漏故障

使用Debug Diagnostic Tool排除內存泄漏故障

翻譯自:https://mssqlwiki.com/2012/12/06/debugging-memory-leaks-using-debug-diagnostic-tool/

專注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)莆田免費做網(wǎng)站提供優(yōu)質的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了數(shù)千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉變。


在我之前的博文中(SQL Server內存泄漏),我解釋了如何使用“!heap”命令識別哪個模塊泄漏了內存。有時我們使用“!d”命令來找到模型或者使用搜索內存命令(s)不能通過顯示內存找到原因。

在這種情況下,我們可以使用Debug Diagnostic Tools或者UMDH來跟蹤內存泄漏。這篇博文解釋了如何使用Debug Diagnostics Tools來識別內存泄漏。

下載并安裝Debug Diagnostic Tools從http://www.microsoft.com/en-us/download/details.aspx?id=26798

1.定位到Tools,“Options”->“Preferences”,選擇“Record call stacks immediately when monitoring the leaks”。

使用Debug Diagnostic Tool排除內存泄漏故障


2.定位到“rules”標簽頁,并選擇“add rule”。

3.選擇“Naive(non .Net) memory leak and handle leak”。

4.選擇SQL Server或者跟蹤用于內存泄漏的任何進程。

5.點擊“Next”并保留默認選項(當規(guī)則是完成或失效時,你可以選擇“auto-unload Leak track”)。

6.點擊“Next”并現(xiàn)在激活規(guī)則。

7.Leaktrack.dll已經(jīng)加入到用于跟蹤分配的進程里。

8.現(xiàn)在你可以等待泄漏再次發(fā)生。

-- If you are learning how to troubleshoot SQL Server memory leak follow the steps which we followed in previous post (https://mssqlwiki.com/2012/12/04/sql-server-memory-leak/)to leak the memory.
-- Download HeapLeak.dll from this link.
-- Create  an extended stored procedure in SQL Server
sp_addextendedproc ‘HeapLeak’,‘C:\HeapLeakdll\HeapLeak.dll’
-- Let us execute this Extended SP 30 times and leak memory.
exec HeapLeak
go 30


9.當你猜測內存泄漏時,定位到“rules”,并通過右擊“Leak rule”執(zhí)行一個完整的用戶dump。

使用Debug Diagnostic Tool排除內存泄漏故障


10.在dump被捕獲后,定位到高級分析標簽頁,添加數(shù)據(jù)文件并選擇我們生成的dump。

11.定位到Tools,“Options”->“set the symbol path for analysis”。默認的Microsoft symbol path在下面。

srv*c:\Websymbols*http://msdl.microsoft.com/download/symbols;c:\Release
重要的:使用加載到SQL Server里的DLL的符號路徑替代c:\Release (可選的)

12.在可用的分析腳本,選擇內存壓力分析器(memory analysis.asp)。

13.點擊“Start Analysis”。

使用Debug Diagnostic Tool排除內存泄漏故障


14.根據(jù)加載符號的時間消耗,分析可能要花費一點時間。當分析完成,會生成并打開一個HTML報告。這個HTML報告默認存儲在C:\Program Files\DebugDiag\Reports\ 可以用于后續(xù)參考。

我附加了一個使用heapleak.dll內存泄漏時收集的示例報表,在這里http://sdrv.ms/TH1qfR。你可以使用它作為參考。

Debug Diagnostic Tool的內存壓力分析器生成的報表有分析總結和以下表格內存。

sqlservr.exe__…………dmp
   Virtual Memory Analysis Report
   Heap Analysis Report
   Leak Analysis Report
   Outstanding allocation summary
    Detailed module report (Memory)
    Detailed module report (Handles)

15.分析總結是報表中不錯部分定位哪個模塊泄漏了內存。查看以下報表。

使用Debug Diagnostic Tool排除內存泄漏故障


16.報表已清晰的表明HeapLeak.dll有255MB顯著的分配。在heapleak.dll里“Sub”函數(shù)用于在偏移量23處分配了該內存。

17.查看虛擬內存總結。它給出了在虛擬地址孔家哪里關于內存分布的完整圖片。在以下摘要里保留是1.57GB,這在32位SQL Server里是正常的,但是本地堆內存有272.94MB是不正常的。

查看堆摘要,有50個堆。

使用Debug Diagnostic Tool排除內存泄漏故障

使用Debug Diagnostic Tool排除內存泄漏故障18.現(xiàn)在查看顯著的分配總結。它給出了分配總數(shù)和分配大小的前10個模塊。在以下摘要HeapLeak占用255.6MB大小里的26182。
注意:在這個報表里它是HeapLeak,但是在實踐中它可能是泄漏內存的任何模塊。

使用Debug Diagnostic Tool排除內存泄漏故障


19.你也可以查看詳細的模塊報告(Memory)。它給出了內存分配,從每個模塊以及函數(shù)和分配內存的源行(如果你對所有加載的模塊設置符號)。

使用Debug Diagnostic Tool排除內存泄漏故障


現(xiàn)在我們確認HeapLeak.dll里的Sub函數(shù)在行號為14位置分配了255MB,并且未釋放。這個報表也給你callstack示例,顯示了當函數(shù)分配內存時的代碼路徑。參考示例HTML報表文件http://sdrv.ms/TH1qfR。


分享名稱:使用DebugDiagnosticTool排除內存泄漏故障
URL地址:http://weahome.cn/article/psjjpo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部