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

Visual Studio 디버깅 경고 창 - You are debugging a Release build of ...

Visual Studio로 디버깅 중 특정 DLL에 대해 다음과 같은 경고 창이 뜹니다.

dbg_stop_continue_dlg_1.png

You are debugging a Release build of ....dll. Using Just My Code with Release builds using compiler optimizations results in a degraded debugging experience (e.g. breakpoints will not be hit).


로딩된 DLL이 정말 디버그 모드로 빌드가 안된 것인지 우선 확인이 필요한데요. 이를 위해 "Ctrl + Alt + U"를 눌러 Modules 창을 띄우면 다음과 같이 문제가 되는 DLL의 정확한 위치를 알 수 있습니다.

Test.Deployment.dll C:\Users\...\AppData\Local\Temp\Temporary ASP.NET Files\root\e340c117\16ede91d\assembly\dl3\4f9f32bc\3dfbd40c_939fd201\Test.Deployment.dll

그런데... Modules 창에는 분명히 "Symbols loaded."라는 메시지와 함께 "C:\...\Test.Deployment.pdb" 파일이 선택되었다고 합니다. 즉, 디버거를 위한 PDB 파일은 정상적으로 제공된 상태입니다.

다음 단계로, 해당 DLL을 .NET Reflector로 로딩한 후 assembly 수준의 Debuggable 특성을 확인한 결과 2로 나왔습니다.

[assembly: System.Diagnostics.Debuggable(0x02)]

이 값의 의미는,

DebuggableAttribute Class
; https://docs.microsoft.com/en-us/dotnet/api/system.diagnostics.debuggableattribute

[ComVisible(true)]
[Flags]
public enum DebuggingModes
{
    None = 0,
    Default = 1,
    IgnoreSymbolStoreSequencePoints = 2,
    EnableEditAndContinue = 4,
    DisableOptimizations = 256
}

단지 IgnoreSymbolStoreSequencePoints가 지정된 것에 불과합니다. 대개의 경우, Release 모드로 빌드하면 Debuggable(2)로 뜨고, Debug 모드로 빌드하면 다음과 같은 구성의,

0x107 = 263
        DisableOptimizations | EnableEditAndContinue | IgnoreSymbolStoreSequencePoints | Default

Debuggable(0x107)로 나오기 때문에 분명히 Release 빌드로 된 것이 맞습니다. 음... 정말 이상하군요. ^^

문제를 밝혀내기 위해 DLL을 참조하는 프로젝트의 .csproj 파일에서 참조 대상을 살펴봤습니다.

<ProjectReference Include="..\Externals\Test.Deployment\Test.Deployment.csproj">
    <Project>{ac0d50da-96df-4395-87d4-de04c2c232ae}</Project>
    <Name>Test.Deployment</Name>
</ProjectReference>

분명히 프로젝트 참조로 되어 있고, Test.Deployment.csproj의 속성 창을 띄워도 Debug 빌드로 명시가 되어 있습니다. 오호~~~ 정말 신기한 경우입니다. ^^;



그래도 우여곡절 끝에 다행히 원인이 밝혀졌습니다. ^^ 해당 프로젝트에 포함된 AssemblyInfo.cs 파일에 다음과 같이 Debuggable 특성의 값이 명시되어 있던 것이 문제였습니다.

[assembly: System.Diagnostics.Debuggable(System.Diagnostics.DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)]

위의 특성 값이 명시된 사연은 이러합니다. 해당 소스 코드는 .NET Reflector를 통해 DLL로부터 "Export Source Code..." 기능으로 얻은 것이었는데, 마침 그 원본 DLL의 빌드 상태가 Release 빌드였기 때문에 그 특성이 그대로 소스 코드로 출력된 것이었습니다.

정리하자면, .NET Reflector와 같은 역 어셈블 도구로 구한 소스 코드의 경우 지정된 Debuggable 특성의 값을 지워주는 것이 권장됩니다. ^^





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







[최초 등록일: ]
[최종 수정일: 7/17/2021]

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

비밀번호

댓글 작성자
 




1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13854정성태12/27/20245865C/C++: 186. Golang - 콘솔 응용 프로그램을 NT 서비스를 지원하도록 변경파일 다운로드1
13853정성태12/26/20244807디버깅 기술: 213. Windbg - swapgs 명령어와 (Ring 0 커널 모드의) FS, GS Segment 레지스터
13852정성태12/25/20245900디버깅 기술: 212. Windbg - (Ring 3 사용자 모드의) FS, GS Segment 레지스터파일 다운로드1
13851정성태12/23/20245097디버깅 기술: 211. Windbg - 커널 모드 디버깅 상태에서 사용자 프로그램을 디버깅하는 방법
13850정성태12/23/20246221오류 유형: 940. "Application Information" 서비스를 중지한 경우, "This file does not have an app associated with it for performing this action."
13849정성태12/20/20246190디버깅 기술: 210. Windbg - 논리(가상) 주소를 Segmentation을 거쳐 선형 주소로 변경
13848정성태12/18/20245685디버깅 기술: 209. Windbg로 알아보는 Prototype PTE파일 다운로드2
13847정성태12/18/20245758오류 유형: 939. golang - 빌드 시 "unknown directive: toolchain" 오류 빌드 시 이런 오류가 발생한다면?
13846정성태12/17/20246316디버깅 기술: 208. Windbg로 알아보는 Trans/Soft PTE와 2가지 Page Fault 유형파일 다운로드1
13845정성태12/16/20245162디버깅 기술: 207. Windbg로 알아보는 PTE (_MMPTE)
13844정성태12/14/20246676디버깅 기술: 206. Windbg로 알아보는 PFN (_MMPFN)파일 다운로드1
13843정성태12/13/20245192오류 유형: 938. Docker container 내에서 빌드 시 error MSB3021: Unable to copy file "..." to "...". Access to the path '...' is denied.
13842정성태12/12/20245380디버깅 기술: 205. Windbg - KPCR, KPRCB
13841정성태12/11/20246017오류 유형: 937. error MSB4044: The "ValidateValidArchitecture" task was not given a value for the required parameter "RemoteTarget"
13840정성태12/11/20245265오류 유형: 936. msbuild - Your project file doesn't list 'win' as a "RuntimeIdentifier"
13839정성태12/11/20246232오류 유형: 936. msbuild - error CS1617: Invalid option '12.0' for /langversion. Use '/langversion:?' to list supported values.
13838정성태12/4/20245954오류 유형: 935. Windbg - Breakpoint 0's offset expression evaluation failed.
13837정성태12/3/20246746디버깅 기술: 204. Windbg - 윈도우 핸들 테이블 (3) - Windows 10 이상인 경우
13836정성태12/3/20245295디버깅 기술: 203. Windbg - x64 가상 주소를 물리 주소로 변환 (페이지 크기가 2MB인 경우)
13835정성태12/2/20246728오류 유형: 934. Azure - rm: cannot remove '...': Directory not empty
13834정성태11/29/20246704Windows: 275. C# - CUI 애플리케이션과 Console 윈도우 (Windows 10 미만의 Classic Console 모드인 경우) [1]파일 다운로드1
13833정성태11/29/20246078개발 환경 구성: 737. Azure Web App에서 Scale-out으로 늘어난 리눅스 인스턴스에 SSH 접속하는 방법
13832정성태11/27/20245717Windows: 274. Windows 7부터 도입한 conhost.exe
13831정성태11/27/20245067Linux: 111. eBPF - BPF_MAP_TYPE_PERF_EVENT_ARRAY, BPF_MAP_TYPE_RINGBUF에 대한 다양한 용어들
13830정성태11/25/20246569개발 환경 구성: 736. 파이썬 웹 앱을 Azure App Service에 배포하기
13829정성태11/25/20246693스크립트: 67. 파이썬 - Windows 버전에서 함께 설치되는 py.exe
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...