Microsoft MVP성태의 닷넷 이야기
MiniDumpWriteDump API로 덤프수집을 했는데요.. [링크 복사], [링크+제목 복사],
조회: 6939
글쓴 사람
치르바
홈페이지
첨부 파일
 
(연관된 글이 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)
5931이대희4/2/20245405Windows 앱 SDK C# 템플릿의 용도가 무엇인지요? [1]
5930vict...2/22/20246741ef core, FromSqlRaw 맵핑 질문입니다. [4]
5929a2/17/20245973.Net 8 에서 디버거 변경 [1]
5928vict...2/5/20247082wpf에서 대량 데이터 보여주는 방법 추천 부탁드립니다. [1]
5926엄태영1/12/20247314잘못된 Task 사용으로 인한 데드락 관련 질문 입니다. [3]
5925Euni...12/22/20236568Visual Studio에서 nodejs 사용시 npm install -g @vue/cli 실행시 오류 [1]
5924Euni...12/21/20236768Visual Studio에서 nodejs 사용시 C:\Program Files\nodejs\\node.exe" "C:\Program Files\nodejs\\node_modules\npm\bin\npm-cli.js" prefix -g 를 찾지 못하는 설치 오류 [2]
5923정두호12/4/20237177MSSQL 데이터 전송과 공유폴더의 데이터 전송 차이점 [1]
5922Heeg...10/27/20239487C++의 double pointer를 C#에서 구현하는 방법이 잘 안됩니다. [3]
5921한예지 donator10/3/20239020마샬링 정의 및 목적이 궁금합니다. [5]
5920한예지 donator10/3/20238244C#과 WIN32 API 관계 질문드립니다. [4]
5919이건우9/27/20237679WinForm의 로딩속도 관련 질문입니다 [2]
5917한예지 donator9/14/20237689동기화 도구 질문 있습니다. [4]
5916한예지 donator9/3/20238105Thread.Sleep(500), await Task.Delay(500), Task.Delay(500) 차이점이 궁금합니다. [2]
5915한예지 donator8/30/20238171비동기 코드를 for 문 안에 작성한 경우 제어 변수가 올바르게 동작하지 않는 이유가 궁금합니다. [3]
5914한상욱8/11/20237897.net wpf에서 skiasharp 의 skelement 를 canvas로 사용 하고 있습니다. [1]
5913김태우8/10/20237823지역변수로 이해하는 메서드매개변수 게시글 댓글 [3]
5912guest4/25/202312637[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3]
5911guest4/24/20238256Form1.cs와 외부 class.cs와 통신 (static async method포함) [4]파일 다운로드1
5910guest4/24/20238040Async 메서드와 try~catch [1]
5909guest4/22/20238677Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/20238491텅빈 원그리기 [5]
5907민성4/21/20237890안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/20238166Dispatcher 서비스 구현 질문 [1]
5905guest4/20/20238911tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/20238797[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...