Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 17. TFS Team Build + Symbol Server [링크 복사], [링크+제목 복사],
조회: 25215
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 4개 있습니다.)


TFS Team Build + Symbol Server


이번엔 Symbol Server와 Team Build를 연결해 보겠습니다. Symbol Server는 해당 바이너리 모듈에 대한 PDB 파일 정보를 내려받을 수 있는 서버인데, 이에 대한 개략적인 구성 방법은 아래의 아티클에서 이미 살펴봤었습니다.

Symbol Server 생성 
; https://www.sysnet.pe.kr/2/0/323

사실, 위의 내용만 알면 Team Build와 연결하는 것은 그다지 어렵지 않습니다. Build Task에 symstore만 실행시켜 주면 되기 때문입니다. 그래도 기왕 알아보기로 했으니 ^^ 어떻게 할 것인지 써보도록 하겠습니다.

이를 테스트 하기 위해서는 다음과 같은 서버들이 필요합니다.

  • 웹 서버
  • TFS 서버

개략적인 시나리오를 설명드리면, 우선 TFS 서버는 팀 빌드를 하고, 그 빌드와 연관된 PDB 파일들을 웹 서버의 특정 폴더에 보낼 것입니다. 그다음, 클라이언트 측에서 VS.NET 2008의 Symbol Server에 해당 웹 서버 주소를 포함하고 디버그를 시작하면 어셈블리 모듈에 맞는 PDB 파일을 다운로드 받아서 디버깅시에 사용하게 됩니다.

단계별로, 한번 정리해 볼까요! ^^


1. 테스트를 위한 Team 프로젝트 및 Team Build 구성
저같은 경우에는 다음과 같이 "BaseClassLibrary"라는 Team 프로젝트를 만들고 "FastBuild"라는 팀 빌드를 구성해 놓았습니다.

[그림 1: 테스트용 팀 프로젝트]
symbol_server_plus_tfs_server_1.png

2. symstore 실행 - 팀 빌드 결과물을 웹 서버에 보관
TFS 빌드 서버에 Debugging Tools for Windows를 설치하고, 해당 팀 빌드 프로젝트를 편집해서 다음과 같은 빌드 태스크를 추가합니다.

<Target Name="AfterDropBuild">
    <!-- PDB Symbol 배포 -->
    <Exec IgnoreExitCode="false" 
             Command="symstore add /r /f $(OutDir)*.* /s \\web2008\Symbols /t $(TeamProject) /v $(BuildNumber) " />
</Target>

  • $(TeamProject) 등의 값들은 "Team Build 에 사용되는 각종 Property 값"을 참고하십시오.
  • \\web2008\Symbols는 웹 서버의 공유 폴더이고, "Virtual Application" 폴더로 연결되어 있습니다.
  • symstore를 실행시키는 계정은 팀 빌드를 구동시키는 프로세스인 "TFSBuildService.exe"에 대해 작업 관리자에서 확인해 보면 됩니다.
  • \\web2008\Symbols 공유 폴더에는 "TFSBuildService.exe"를 구동시키는 계정에 대해 "쓰기" 권한이 부여되어 있어야 합니다.
  • web2008 웹 서버의 Symbols 가상 애플리케이션 설정에는 ".dll/.exe/.pdb"에 대한 MIME 형식을 "application/octet-stream"으로 설정해 두어야 합니다. 자세한 사항은 "Symbol Server 생성"을 참조하십시오.
  • symstore.exe에 대한 실행파일 경로는 Command 인자에 직접 지정해도 되고, 전역 환경 변수 PATH에 설정해도 됩니다.

이것으로, Symbol Server 구성 끝입니다. ^^




이제 테스트를 하면 되는데요. 사실, 이에 대한 설명은 이미 다음의 아티클에서 자세히 다뤘습니다.

3.7. Microsoft의 PDB 파일 관리 
; https://www.sysnet.pe.kr/2/0/321

그래도, 여기서 다시 한번 제가 구성한 예제 프로젝트를 가지고 테스트 해보겠습니다.

1. 테스트 프로젝트 다운로드
"예제 프로젝트"를 다운로드 받아서, 여러분들의 VS.NET 2008에서 로드합니다.

2. 예제 프로젝트에서 사용하는 "BclExtension.dll"의 PDB 파일이 놓인 Symbol 서버를 지정
아래와 같이 "Tools" / "Options" 메뉴에서 Symbol Server를 지정합니다.

[그림 2: 테스트 DLL의 PDB 심벌 서버 지정]
symbol_server_plus_tfs_server_2.png

3. PDB 다운로드 확인
이제, 위에서 다운로드 받은 예제 프로젝트로 "F5" 디버깅을 시작해 보면, 아래 그림과 같이 "BclExtension.dll"에 대해서 "Symbols loaded." 상태가 되는 것을 확인할 수 있습니다. 물론, "E:\cachedProducts" 폴더에는 "BclExtension.pdb"에 대한 PDB 파일도 다운로드 되어져 있습니다.

[그림 3: 디버깅 시에 테스트 DLL 심벌 파일 로드]
symbol_server_plus_tfs_server_3.png




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

[연관 글]






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

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

비밀번호

댓글 작성자
 



2018-03-05 01시04분
Symbol Server 설정 (공유, HTTP)
; http://platformengineer.tistory.com/39
정성태

... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12831정성태9/6/20216809VC++: 148. Golang - 채널에 따른 다중 작업 처리파일 다운로드1
12830정성태9/6/20219204오류 유형: 761. Internet Explorer에서 파일 다운로드 시 "Your current security settings do not allow this file to be downloaded." 오류
12829정성태9/5/202110771.NET Framework: 1115. C# 10 - (14) 구조체 타입에 기본 생성자 정의 가능파일 다운로드1
12828정성태9/4/20218906.NET Framework: 1114. C# 10 - (13) 단일 파일 내에 적용되는 namespace 선언파일 다운로드1
12827정성태9/4/20218817스크립트: 27. 파이썬 - 웹 페이지 데이터 수집을 위한 scrapy Crawler 사용법 요약
12826정성태9/3/202111093.NET Framework: 1113. C# 10 - (12) 문자열 보간 성능 개선 [1]파일 다운로드1
12825정성태9/3/20218641개발 환경 구성: 603. GoLand - WSL 환경과 연동
12824정성태9/2/202117801오류 유형: 760. 파이썬 tensorflow - Dst tensor is not initialized. 오류 메시지
12823정성태9/2/20217250스크립트: 26. 파이썬 - PyCharm을 이용한 fork 디버그 방법
12822정성태9/1/202112539오류 유형: 759. 파이썬 tensorflow - ValueError: Shapes (...) and (...) are incompatible [2]
12821정성태9/1/20218174.NET Framework: 1112. C# - .NET 6부터 공개된 ISpanFormattable 사용법
12820정성태9/1/20218400VC++: 147. Golang - try/catch에 대응하는 panic/recover [1]파일 다운로드1
12819정성태8/31/20218537.NET Framework: 1111. C# - FormattableString 타입
12818정성태8/31/20217751Windows: 198. 윈도우 - 작업 관리자에서 (tensorflow 등으로 인한) GPU 연산 부하 보는 방법
12817정성태8/31/202110466스크립트: 25. 파이썬 - 윈도우 환경에서 directml을 이용한 tensorflow의 AMD GPU 사용 방법
12816정성태8/30/202115802스크립트: 24. 파이썬 - tensorflow 2.6 NVidia GPU 사용 방법 [2]
12815정성태8/30/20218922개발 환경 구성: 602. WSL 2 - docker-desktop-data, docker-desktop (%LOCALAPPDATA%\Docker\wsl\data\ext4.vhdx) 파일을 다른 디렉터리로 옮기는 방법
12814정성태8/30/202111368.NET Framework: 1110. C# 11 - 인터페이스 내에 정적 추상 메서드 정의 가능 (DIM for Static Members) [2]파일 다운로드1
12813정성태8/29/20219429.NET Framework: 1109. C# 10 - (11) Lambda 개선파일 다운로드1
12812정성태8/28/20219097.NET Framework: 1108. C# 10 - (10) 개선된 #line 지시자
12811정성태8/27/20219272Linux: 44. 윈도우 개발자를 위한 리눅스 fork 동작 방식 설명 (파이썬 코드)
12810정성태8/27/20218019.NET Framework: 1107. .NET Core/5+에서 동적 컴파일한 C# 코드를 (Breakpoint도 활용하며) 디버깅하는 방법 - #line 지시자파일 다운로드1
12809정성태8/26/20218720.NET Framework: 1106. .NET Core/5+에서 C# 코드를 동적으로 컴파일/사용하는 방법 [1]파일 다운로드1
12808정성태8/25/20219949오류 유형: 758. go: ...: missing go.sum entry; to add it: go mod download ...
12807정성태8/25/20219995.NET Framework: 1105. C# 10 - (9) 비동기 메서드가 사용할 AsyncMethodBuilder 선택 가능파일 다운로드1
12806정성태8/24/20217559개발 환경 구성: 601. PyCharm - 다중 프로세스 디버깅 방법
... 31  32  [33]  34  35  36  37  38  39  40  41  42  43  44  45  ...