Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

windbg - 풀 덤프 파일로부터 텍스트 파일의 내용을 찾는 방법

예전에 설명한 대로,

windbg - 덤프 파일과 handle 정보
; https://www.sysnet.pe.kr/2/0/1836

사용자 모드(user mode)의 풀 덤프 파일로는 핸들 값으로부터 별다르게 얻을 수 있는 정보가 없습니다. 파일명조차 못 구하는데 파일 내용을 알아내는 것은 말할 필요도 없습니다.

단지, 우회적인 방법을 사용해야 하는데요. 가장 좋은 방법은, 로드된 파일이 정적 변수에 담겨 있는 경우입니다. 그럴 때는 그냥 찾아들어가서 해당 변수의 내용을 덤프하면 파일의 내용을 얻을 수 있습니다.

만약, 그런 변수가 있는지 알 수 없다면 차선책으로 문자열 검색을 해보는 것입니다. 이런 경우 해당 파일의 내용을 식별해 줄 가장 최선의 문자열을 검색어로 쓰는 것입니다.

가령 예를 들어보면...

다음과 같은 간단한 콘솔 프로그램을 보면,

using System;
using System.IO;

namespace ConsoleApplication1
{
    class Program
    {
        static string txt = null;
        static void Main(string[] args)
        {
            txt = File.ReadAllText("test.txt");

            Console.ReadLine();
        }
    }
}

다음의 내용을 담은 test.txt 파일을 로드하는데,

test is good

The .dump command creates a user-mode or kernel-mode crash dump file. ... .suspend_ui (Suspend WinDbg Interface) .symfix (Set Symbol Store Path) .... You can specify a full path and file name or just the file name. If the file name contains ...

이런 프로그램의 풀 덤프 파일을 windbg에서 디버깅할 때 메모리를 검색해 보는 것입니다.

0:000> s -u 0 L?ffffffff`ffffffff "test is good"   
00000207`5eab5068  0074 0065 0073 0074 0020 0069 0073 0020  t.e.s.t. .i.s. .
00000207`5eab58d8  0074 0065 0073 0074 0020 0069 0073 0020  t.e.s.t. .i.s. .
00000207`5eab6b84  0074 0065 0073 0074 0020 0069 0073 0020  t.e.s.t. .i.s. .

명령어 s
-u : 유니코드 검색 (ascii인 경우 -a)
0 : 시작 주소 지정
L?ffffffff`ffffffff : 범위를 64비트 끝으로 지정.

검색 결과가 3개가 나왔는데요. 각각 du 명령어로 전체 내용을 확인할 수 있습니다. (또는 Alt+5를 눌러 메모리 창을 띄운 후 주소 값에 따라 덤프해볼 수 있습니다.)

0:000> du 00000207`5eab5068  
00000207`5eab5068  "test is good....The .dump comman"
00000207`5eab50a8  "d creates a user-mode or kernel-"
00000207`5eab50e8  "mode crash dump file. ... .suspe"
00000207`5eab5128  "nd_ui (Suspend WinDbg Interface)"
00000207`5eab5168  " .symfix (Set Symbol Store Path)"
00000207`5eab51a8  " .... You can specify a full pat"
00000207`5eab51e8  "h and file name or just the file"
00000207`5eab5228  " name. If the file name contains"
00000207`5eab5268  " ..."

0:000> du 00000207`5eab58d8  
00000207`5eab58d8  "test is good...."

0:000> du 00000207`5eab6b84  
00000207`5eab6b84  "test is good....The .dump comman"
00000207`5eab6bc4  "d creates a user-mode or kernel-"
00000207`5eab6c04  "mode crash dump file. ... .suspe"
00000207`5eab6c44  "nd_ui (Suspend WinDbg Interface)"
00000207`5eab6c84  " .symfix (Set Symbol Store Path)"
00000207`5eab6cc4  " .... You can specify a full pat"
00000207`5eab6d04  "h and file name or just the file"
00000207`5eab6d44  " name. If the file name contains"
00000207`5eab6d84  " ..."

소개한 방법이 조금은 허탈하겠지만, 어쩔 수 없습니다.... 운입니다. ^^ 따라서 대용량의 응용 프로그램이라면 저렇게 쉽게 찾기 힘들 수 있습니다.

(혹시 자신만의 팁이 있는 분은 덧글 좀. ^^)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 4/22/2016]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  114  115  116  [117]  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11091정성태11/3/201629034VC++: 104. std::call_once를 이용해 thread-safe한 Singleton 객체 생성파일 다운로드1
11090정성태11/1/201630593VC++: 103. C++ CreateTimerQueue, CreateTimerQueueTimer 예제 코드 [9]파일 다운로드1
11089정성태11/1/201631259디버깅 기술: 82. Windows 10을 위한 Symbol(PDB) 파일 내려받는 방법 [2]
11088정성태11/1/201633197.NET Framework: 617. C# - AForge.NET을 이용한 MP4 동영상 파일 재생 [7]파일 다운로드1
11087정성태11/1/201627473.NET Framework: 616. AForge.Video.FFMPEG를 최신 버전의 ffmpeg 파일로 의존성을 변경하는 방법파일 다운로드1
11086정성태11/1/201622300오류 유형: 366. The Microsoft Passport Container service terminated with the following error: General access denied error
11085정성태10/27/201637691.NET Framework: 615. C# - AForge.NET을 이용한 웹캠 영상 출력 [2]파일 다운로드1
11084정성태10/26/201625223오류 유형: 365. The User Profile Service service failed to the sign-in.
11083정성태10/26/201631702Windows: 131. 윈도우 10에서 사라진 "Adapters and Bindings" 네트워크 우선 순위 조정 기능 [1]
11082정성태10/26/201634705.NET Framework: 614. C# - DateTime.Ticks의 정밀도 [4]파일 다운로드1
11081정성태10/26/201623975오류 유형: 364. You need to fix your Microsoft Account for apps on your other devices to be able to launch apps and continue experiences on this device.
11080정성태10/24/201628203Windows: 130. Windows Server 2016 Nano 서버 설치 방법
11079정성태10/21/201625176Windows: 129. Windows Server 2016 설치 CD에 있는 Convert-WindowsImage.ps1 사용 방법 정리
11078정성태10/21/201626357Windows: 128. Windows Server 2016 Nano 서버 VHD 이미지 만드는 방법 - TP5 기준
11077정성태10/21/201623957오류 유형: 363. Active Directory 서버의 NETLOGON 서비스가 멈췄을 때 발생하는 문제
11076정성태10/21/201624200오류 유형: 362. 윈도우 백업 시 오류 - 0x80780040
11075정성태10/20/201624006Windows: 127. Convert-WindowsImage.ps1 사용 방법 정리
11074정성태10/20/201633497Windows: 126. Windows Server 2016 평가판을 정식 버전으로 라이선스 변경하는 방법
11073정성태10/20/201629891.NET Framework: 613. 윈도우 데스크톱 응용 프로그램(예: Console)에서 알림 메시지(Toast notifications) 띄우기 [1]파일 다운로드1
11072정성태10/20/201626741VC++: 102. 새로 추가한 ATL COM 객체가 regsvr32.exe로 등록이 안 되는 문제
11071정성태10/20/201629709.NET Framework: 612. UWP(유니버설 윈도우 플랫폼) 앱에서 콜백 함수 내에서의 UI 요소 접근 방법 [1]
11070정성태10/20/201622831Windows: 125. 윈도우 서버 2016 마이그레이션
11069정성태10/19/201631121.NET Framework: 611. C++ 개발자들을 위한 C# Thread 동작 방식 [2]
11068정성태10/19/201633893Windows: 124. 윈도우 운영체제의 시간 함수 (5) - TSC(Time Stamp Counter)와 QueryPerformanceCounter [12]파일 다운로드1
11067정성태10/18/201629262Windows: 123. 윈도우 운영체제의 시간 함수 (4) - RTC, TSC, PM Clock, HPET Timer [2]
11066정성태10/17/201628875Windows: 122. 윈도우 운영체제의 시간 함수 (3) - QueryInterruptTimePrecise, QueryInterruptTime 함수파일 다운로드1
... 106  107  108  109  110  111  112  113  114  115  116  [117]  118  119  120  ...