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)
13961정성태7/5/20255252디버깅 기술: 222. WinDbg 분석 사례 - IISreset 시점에 w3wp.exe의 crash 발생
13960정성태7/3/20255811개발 환경 구성: 752. ProcDump - C/C++ 예외 코드 필터를 지정한 덤프 생성 [2]
13959정성태6/25/20254962오류 유형: 966. Ubuntu - ping: connect: Network is unreachable
13958정성태6/21/20255789닷넷: 2339. C# - Phi-4-multimodal 모델의 GPU 가속 방법 (ORT 사용)파일 다운로드1
13957정성태6/20/20256624닷넷: 2338. C# / Foundry Local - Phi-4-multimodal 모델을 사용하는 방법 [1]
13956정성태6/19/20256656개발 환경 구성: 751. Triton Inference Server의 Python Backend 프로세스
13955정성태6/18/20256375오류 유형: 965. Hugging Face 모델 다운로드 시 "requests.exceptions.HTTPError: 401 Client Error: Unauthorized for url: ..." 오류
13954정성태6/18/20254886닷넷: 2337. C# - Hugging Face에 공개된 LLM 모델을 Foundry Local에서 사용하는 방법파일 다운로드1
13953정성태6/16/20255373스크립트: 78. 파이썬 - 소스 코드의 파일 경로를 지정한 모듈 로드
13952정성태6/15/20255512닷넷: 2336. C# - IValueTaskSource로 인해 주의가 필요한 ValueTask 호출파일 다운로드1
13951정성태6/15/20255812오류 유형: 964. Outlook - 일정이 "You cannot make changes to contents of this read-only folder." 오류 메시지로 삭제가 안 되는 경우
13950정성태6/12/20256661닷넷: 2335. C# - 간단하게 구현해 보는 IValueTaskSource 예제파일 다운로드1
13949정성태6/11/20256413오류 유형: 963. SignTool - "Error: SignerSign() failed." (-2146869243/0x80096005)
13948정성태6/10/20255300오류 유형: 962. 파이썬 - Linux 환경 + TCP 서버 소켓을 사용하는 프로세스 종료 후 재실행하는 경우 "OSError: [Errno 98] Address already in use" 오류 발생
13947정성태6/9/20256530개발 환경 구성: 750. 파이썬 - Azure App Service에 응용 프로그램 배포 후의 환경
13946정성태6/9/20256232개발 환경 구성: 749. 파이썬 - Azure App Service에 응용 프로그램 배포하기 전의 환경
13945정성태6/7/20255313오류 유형: 961. 파이썬 + conda - mysqlclient 사용 시 "NameError: name '_mysql' is not defined" 에러
13944정성태6/7/20258430오류 유형: 960. The trust relationship between this workstation and the primary domain failed. - 네 번째 이야기
13943정성태6/6/20255822개발 환경 구성: 748. Windows + Foundry Local - 로컬에서 AI 모델 활용 [1]
13942정성태6/5/20254955오류 유형: 959. winget 설치 시 "0x80d02002 : unknown error"
13941정성태6/2/20255981닷넷: 2334. C# - cpuid 명령어를 이용한 CPU 제조사 문자열 가져오기파일 다운로드1
13940정성태6/1/20256353C/C++: 188. C++의 32비트 + Release 어셈블리 코드를 .NET으로 포팅할 때 주의할 점파일 다운로드1
13939정성태5/29/20257250오류 유형: 958. NVIDIA Triton Inference Server - version `GLIBCXX_3.4.32' not found (required by /opt/tritonserver/backends/python/triton_python_backend_stub)
13938정성태5/29/20255207개발 환경 구성: 747. 파이썬 - WSL/docker에 구성한 Triton 예제 개발 환경
13937정성태5/24/20255949개발 환경 구성: 746. Windows + WSL2 환경에서 (tensorflow 등의) NVIDIA GPU 인식
13936정성태5/23/20255199개발 환경 구성: 745. Linux / WSL 환경에 Miniconda 설치하기
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...