Microsoft MVP성태의 닷넷 이야기
MiniDumpWriteDump API로 덤프수집을 했는데요.. [링크 복사], [링크+제목 복사]
조회: 2181
글쓴 사람
치르바
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

https://www.sysnet.pe.kr/2/0/1517?pageno=15
게시글을 참고하여 MiniDumpWriteDump API로 덤프를 수집하는 exe를 개발했습니다.

DumpType에 MiniDumpWithHandleData 플래그를 추가했는데도 덤프 분석할 때(WinDbg (x64).exe)
!handle 명령어를 수행하면 아래처럼 핸들 정보가 없는 것처럼 나옵니다.

ERROR: !handle: extension exception 0x80004002.
    "Unable to read handle information"

.dumpdebug 명령을 수행해서 나오는 결과를 보면 Flags에 0x1026이 표시됩니다.(덤프 타입에는 분명히 들어갔음)
0:000> .dumpdebug
----- User Mini Dump Analysis
MINIDUMP_HEADER:
Version         A793 (A061)
NumberOfStreams 15
Flags           1026
                0002 MiniDumpWithFullMemory
                0004 MiniDumpWithHandleData
                0020 MiniDumpWithUnloadedModules
                1000 MiniDumpWithThreadInfo

혹시 이와 관련된 어떤 정보라도 알고 계시는 것이 있을까요?
procdump.exe -ma {process}를 통해서 수집한 덤프에는 핸들 정보가 정상적으로 들어있습니다.


[연관 글]






[최초 등록일: ]
[최종 수정일: 2/3/2023]


비밀번호

댓글 작성자
 



2023-02-03 07시17분
코드를 다시 테스트해봐도 딱히 문제점이 없습니다. MiniDumpWithHandleData를 빼야 0x80004002 오류가 발생하고, 넣으면 정상적으로 !handle 명령어 결과가 보입니다.

일단 치르바 님이 재현이 되시니까... ^^ MiniDumpType의 다른 flag 값들도 같이 조합해서 해보시면 정상적으로 나오는 경우가 있지 않을까요? MiniDumpWriteDump API가 사실 워낙 간단해서 딱히 그 외에 시도해 볼 만한 것이 없을 것 같습니다.
정성태
2023-02-05 10시21분
아래의 글에,

windbg - Win32 API 호출 시점에 BP 거는 방법
; https://www.sysnet.pe.kr/2/0/13243

procdump가 사용하는 MINIDUMP_TYPE 조합을 설명했으니 참고해서 적용해 보세요. (아마 운영체제마다 허용하는 조합은 다를 수 있습니다.)
정성태
2023-02-06 11시10분
[치르바] 빠른 피드백 감사합니다.
올려주신 링크 참고해서 procdump와 동일한 flag로 수집해봤지만 여전히 handle 정보만 빠지네요..
조금 더 연구해보고 답을 찾게되면 저도 공유드리겠습니다!
[guest]

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5922He...10/27/20231803C++의 double pointer를 C#에서 구현하는 방법이 잘 안됩니다. [3]
5921한예지10/3/20232622마샬링 정의 및 목적이 궁금합니다. [5]
5920한예지10/3/20231767C#과 WIN32 API 관계 질문드립니다. [4]
5919이건우9/27/20231530WinForm의 로딩속도 관련 질문입니다 [2]
5917한예지9/14/20231633동기화 도구 질문 있습니다. [4]
5916한예지9/3/20231745Thread.Sleep(500), await Task.Delay(500), Task.Delay(500) 차이점이 궁금합니다. [2]
5915한예지8/30/20231685비동기 코드를 for 문 안에 작성한 경우 제어 변수가 올바르게 동작하지 않는 이유가 궁금합니다. [3]
5914한상욱8/11/20231653.net wpf에서 skiasharp 의 skelement 를 canvas로 사용 하고 있습니다. [1]
5913김태우8/10/20231852지역변수로 이해하는 메서드매개변수 게시글 댓글 [3]
5912guest4/25/20233415[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3]
5911guest4/24/20232317Form1.cs와 외부 class.cs와 통신 (static async method포함) [4]파일 다운로드1
5910guest4/24/20232067Async 메서드와 try~catch [1]
5909guest4/22/20232279Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/20232200텅빈 원그리기 [5]
5907민성4/21/20231989안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/20232084Dispatcher 서비스 구현 질문 [1]
5905guest4/20/20232118tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/20232216[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
5903guest4/18/20231885fileSystemWatcher 이벤트 관련 질문입니다 [2]
5902guest4/17/20232337c#으로 USB 관련 질문 [2]
5901guest4/17/20232102내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [5]
5900guest4/17/20232944DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [2]파일 다운로드1
5899guest4/17/20232225Dictionary와 Linq [4]
5898차가워4/17/20232027CNTK 교육 문의 [1]
5897guest4/17/20232155Socket스레드와 UI thread [4]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...