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

Web Site Model 프로젝트에서 Trace.WriteLine 출력이 dbgview.exe에서 확인이 안 되는 문제


Web Site 모델에 대해서 생소한 분은 우선 다음의 글을 참조하시고,

Web Site Model 
; https://www.sysnet.pe.kr/2/0/312

그래서, 아래의 글에 잠시 소개되는 것처럼 DLL 없이 순수하게 파일만으로 구성한 웹 사이트를 만드는 것도 가능합니다.

IIS Express - localhost 이외의 호스트 이름으로 접근하는 방법
; https://www.sysnet.pe.kr/2/0/1030

어쨌든! 이런 Web Site 모델의 경우 기본적으로 Debug 및 Trace 개체의 WriteLine 출력이 안되는 것을 확인할 수 있습니다.

// default.aspx 웹 페이지를 방문해도 dbgview.exe에서는 아무런 출력결과도 확인이 안됨
public partial class _Default : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        System.Diagnostics.Debug.WriteLine("Debug.WriteLine");
        System.Diagnostics.Trace.WriteLine("Trace.WriteLine");
    }
}

실제로, 위의 웹 페이지를 방문할 때 default.aspx/cs 파일을 빌드하기 위해 다음과 같이 빌드 프로세스가 실행됩니다.

"C:\Windows\Microsoft.NET\Framework\v4.0.30319\csc.exe" /noconfig /fullpaths @"C:\...[AppDataLocal]...\Temp\Temporary ASP.NET Files\website1\bd62c795\3e1d734d\gfrfbecn.cmdline"


(csc.exe 실행 후 곧바로 지워버리기 때문에) "gfrfbecn.cmdline" 파일의 내용을 확인할 수는 없었지만, 생각해 보면 Debug/Trace 출력이 없음을 이해할 수 있습니다. 빌드는 해야 하는데, 적절한 컴파일 옵션이 주어지지 않았기 때문에 컴파일러 입장에서는 '기본값'으로 .aspx/.cs 파일을 빌드할 수밖에 없었을 것입니다.

그렇다면, 원하는 데로 옵션을 지정해 주어야 할 텐데요. 우선, 상대적으로 간단한 Debug.WriteLine부터 가능하도록 해보겠는데, 이를 위해 다음과 같이 컴파일러에게 디버그 모드로 .aspx/.cs 파일을 빌드하도록 지정해 줄 수 있습니다.

<configuration>
  <system.web>
    <compilation debug="true" targetFramework="4.0" />
    ...[생략]...
  </system.web>
</configuration>

위의 변경 이후에는, default.aspx 웹 페이지를 방문하면 "Debug.WriteLine" 출력을 dbgview.exe에서 확인할 수 있습니다.




Trace.WriteLine 출력은 어떨까요? 아쉽게도 Debug 출력처럼 간단하게 속성 값만 변경해 주는 수준에서는 해결이 안되고 다음과 같이 복잡한 컴파일러 옵션을 재정의 해주어야 합니다.

  <system.codedom>
    <compilers>
      <compiler language="c#;cs;csharp"
              extension=".cs"
              compilerOptions="/d:TRACE"
              type="Microsoft.CSharp.CSharpCodeProvider, System, Version=2.0.3500.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" 
              warningLevel="1" />
    </compilers>
  </system.codedom>
  

아하... 그렇군요. 일반 DLL/EXE 빌드에서와 마찬가지로 TRACE 매크로 상수 값을 compilerOptions 속성에 지정하는 것으로 해결할 수 있습니다. 이제는 정상적으로 Debug/Trace.WriteLine 구문이 동작하는 것을 확인할 수 있습니다.

그런데, 위의 구문을 가만히 보면 compilerOptions가 단지 /d:TRACE 정의만을 위한 것은 아니라는 것을 눈치채셨을 것입니다. 따라서 <compilation debug="true" targetFramework="4.0" />의 debug 속성값을 false로 바꾼 상태에서도 결국 다음과 같이 compilerOptions을 주게 되면 동일하게 Debug/Trace를 활성화시킬 수 있다는 것이고!

<compiler language="c#;cs;csharp"
        extension=".cs"
        compilerOptions="/d:TRACE;DEBUG"

첨부된 파일은 위의 코드를 포함한 예제 프로젝트인데, '웹 사이트 유형'이기 때문에 별도의 csproj 프로젝트 파일이 없습니다.




마치기 전에, 한 가지 언급하자면 compiler 노드의 설정에서 type 값이 중요합니다.

<system.codedom>
    <compilers>
        <compiler language="c#;cs;csharp" extension=".cs" compilerOptions="/d:TRACE"
             type="Microsoft.CSharp.CSharpCodeProvider, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
    </compilers>
</system.codedom>

웹상의 자료를 검색하면, 위의 type 값이 생략된 것을 종종 볼 수 있는데요. 그런 경우 compilerOptions 설정이 전혀 효력이 없었습니다. 또한, system.web/compilation[@targetFramework] 값이 "4.0"이어도 compiler[@type] 내의 Version 속성은 "2.0.0.0"도 허용이 됩니다. (아마도 .NET 2.0도 함께 설치되어 있어야 할 것입니다.)




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







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

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

비밀번호

댓글 작성자
 




... [76]  77  78  79  80  81  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
12036정성태10/14/201925351.NET Framework: 866. C# - 고성능이 필요한 환경에서 GC가 발생하지 않는 네이티브 힙 사용파일 다운로드1
12035정성태10/13/201919565개발 환경 구성: 461. C# 8.0의 #nulable 관련 특성을 .NET Framework 프로젝트에서 사용하는 방법 [2]파일 다운로드1
12034정성태10/12/201918871개발 환경 구성: 460. .NET Core 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 [1]
12033정성태10/11/201923055개발 환경 구성: 459. .NET Framework 프로젝트에서 C# 8.0/9.0 컴파일러를 사용하는 방법
12032정성태10/8/201919197.NET Framework: 865. .NET Core 2.2/3.0 웹 프로젝트를 IIS에서 호스팅(Inproc, out-of-proc)하는 방법 - AspNetCoreModuleV2 소개
12031정성태10/7/201916452오류 유형: 569. Azure Site Extension 업그레이드 시 "System.IO.IOException: There is not enough space on the disk" 예외 발생
12030정성태10/5/201923249.NET Framework: 864. .NET Conf 2019 Korea - "닷넷 17년의 변화 정리 및 닷넷 코어 3.0" 발표 자료 [1]파일 다운로드1
12029정성태9/27/201924094제니퍼 .NET: 29. Jennifersoft provides a trial promotion on its APM solution such as JENNIFER, PHP, and .NET in 2019 and shares the examples of their application.
12028정성태9/26/201919042.NET Framework: 863. C# - Thread.Suspend 호출 시 응용 프로그램 hang 현상을 해결하기 위한 시도파일 다운로드1
12027정성태9/26/201914789오류 유형: 568. Consider app.config remapping of assembly "..." from Version "..." [...] to Version "..." [...] to solve conflict and get rid of warning.
12026정성태9/26/201920222.NET Framework: 862. C# - Active Directory의 LDAP 경로 및 정보 조회
12025정성태9/25/201918520제니퍼 .NET: 28. APM 솔루션 제니퍼, PHP, .NET 무료 사용 프로모션 2019 및 적용 사례 (8) [1]
12024정성태9/20/201920415.NET Framework: 861. HttpClient와 HttpClientHandler의 관계 [2]
12023정성태9/18/201920883.NET Framework: 860. ServicePointManager.DefaultConnectionLimit와 HttpClient의 관계파일 다운로드1
12022정성태9/12/201924849개발 환경 구성: 458. C# 8.0 (Preview) 신규 문법을 위한 개발 환경 구성 [3]
12021정성태9/12/201940644도서: 시작하세요! C# 8.0 프로그래밍 [4]
12020정성태9/11/201923827VC++: 134. SYSTEMTIME 값 기준으로 특정 시간이 지났는지를 판단하는 함수
12019정성태9/11/201917379Linux: 23. .NET Core + 리눅스 환경에서 Environment.CurrentDirectory 접근 시 주의 사항
12018정성태9/11/201916174오류 유형: 567. IIS - Unrecognized attribute 'targetFramework'. Note that attribute names are case-sensitive. (D:\lowSite4\web.config line 11)
12017정성태9/11/201919983오류 유형: 566. 비주얼 스튜디오 - Failed to register URL "http://localhost:6879/" for site "..." application "/". Error description: Access is denied. (0x80070005)
12016정성태9/5/201920004오류 유형: 565. git fetch - warning: 'C:\ProgramData/Git/config' has a dubious owner: '(unknown)'.
12015정성태9/3/201925390개발 환경 구성: 457. 윈도우 응용 프로그램의 Socket 연결 시 time-out 시간 제어
12014정성태9/3/201919125개발 환경 구성: 456. 명령행에서 AWS, Azure 등의 원격 저장소에 파일 관리하는 방법 - cyberduck/duck 소개
12013정성태8/28/201922034개발 환경 구성: 455. 윈도우에서 (테스트) 인증서 파일 만드는 방법 [3]
12012정성태8/28/201926598.NET Framework: 859. C# - HttpListener를 이용한 HTTPS 통신 방법
12011정성태8/27/201926204사물인터넷: 57. C# - Rapsberry Pi Zero W와 PC 간 Bluetooth 통신 예제 코드파일 다운로드1
... [76]  77  78  79  80  81  82  83  84  85  86  87  88  89  90  ...