安定したハンドル数が2000年前後の運用環境(WINDOWS XP + .NET 3.5 SP1)で.NETアプリケーションを実行していますが、未知の状況ではハンドル数が非常に高速になり、 PerfMonツールで監視)。.NETアプリケーションのハンドルリーク、ソースの場所を確認するには?
私は増加期間(まだクラッシュしていない)の間にそこからメモリダンプを作ったとのWinDbgにインポートしたが、全体的にハンドルの概要を参照することができますので、
0:000> !handle 0 0
7229 Handles
Type Count
None 19
Event 504
Section 6108
File 262
Port 15
Directory 3
Mutant 56
WindowStation 2
Semaphore 70
Key 97
Token 2
Process 3
Thread 75
Desktop 1
IoCompletion 9
Timer 2
KeyedEvent 1
驚きを、リークタイプがありますSection
、もっと掘る:
0:000> !handle 0 ff Section
Handle 00007114
Type Section
Attributes 0
GrantedAccess 0xf0007:
Delete,ReadControl,WriteDac,WriteOwner
Query,MapWrite,MapRead
HandleCount 2
PointerCount 4
Name \BaseNamedObjects\MSCTF.MarshalInterface.FileMap.IBC.AKCHAC.CGOOBGKD
No object specific information available
Handle 00007134
Type Section
Attributes 0
GrantedAccess 0xf0007:
Delete,ReadControl,WriteDac,WriteOwner
Query,MapWrite,MapRead
HandleCount 2
PointerCount 4
Name \BaseNamedObjects\MSCTF.MarshalInterface.FileMap.IBC.GKCHAC.KCLBDGKD
No object specific information available
...
...
...
...
6108 handles of type Section
はBaseNamedObjects'
命名規則を見ることができますが、すべてMSCTF.MarshalInterface.FileMap.IBC.***.*****
です。
基本的に私はここで停止し、アプリケーションに情報をリンクすることができませんでした。
誰でも手助けできますか?
[Edit0]
は、GFlags
コマンド(+ust
またはUIを介した)のいくつかの組み合わせを試してみましたがない運で、WinDbgので開かれたダンプは、常に!htrace
を経由して何も見えないので、を使用していたプロセスを添付最終的に私はハンドルをリーク上記のスタックました:
0:033> !htrace 1758
--------------------------------------
Handle = 0x00001758 - OPEN
Thread ID = 0x00000768, Process ID = 0x00001784
0x7c809543: KERNEL32!CreateFileMappingA+0x0000006e
0x74723917: MSCTF!CCicFileMappingStatic::Create+0x00000022
0x7473fc0f: MSCTF!CicCoMarshalInterface+0x000000f8
0x747408e9: MSCTF!CStub::stub_OutParam+0x00000110
0x74742b05: MSCTF!CStubIUnknown::stub_QueryInterface+0x0000009e
0x74743e75: MSCTF!CStubITfLangBarItem::Invoke+0x00000014
0x7473fdb9: MSCTF!HandleSendReceiveMsg+0x00000171
0x7474037f: MSCTF!CicMarshalWndProc+0x00000161
*** ERROR: Symbol file could not be found. Defaulted to export symbols for C:\Windows\system32\USER32.dll -
0x7e418734: USER32!GetDC+0x0000006d
0x7e418816: USER32!GetDC+0x0000014f
0x7e4189cd: USER32!GetWindowLongW+0x00000127
--------------------------------------
をして、私は再び捕まってしまった、スタックは、当社のユーザーコードのいずれかが含まれていないようで、前進のための提案は何ですか?
WPR/Perfviewを使用してハンドルの使用状況をキャプチャし、WPA/Perfviewで解析します。http://geekswithblogs.net/akraus1/archive/2016/03/14/173308.aspx – magicandre1981