Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 17. TFS Team Build + Symbol Server [링크 복사], [링크+제목 복사],
조회: 31388
글쓴 사람
정성태 (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
정성태

... 181  182  [183]  184  185  186  187  188  189  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
441정성태1/23/200730385Windows: 17. 보안 데스크톱에서 활성화되지 않은 UAC 창이 안전할까?
440정성태1/24/200724449.NET Framework: 78. C# 3.0 - Anonymous types [1]
439정성태1/25/200725503.NET Framework: 77. C# 3.0 - Lambda 표현식 [1]
438정성태1/24/200724639.NET Framework: 76. C# 3.0 - 확장 함수
437정성태1/23/200732302Windows: 16. 개발자를 위한 UAC 환경 설정 [3]
436정성태1/17/200721510VS.NET IDE: 42. Orcas 2007년 1월 CTP 버전 설치 [5]
435정성태1/14/200721004기타: 17. 베타 제품과 최종 제품은 다르다 [2]
434정성태2/4/200724766Windows: 15. MIC 환경 구성 - Windows XP와 유사한 보안 설정 [4]
433정성태1/12/200734191Windows: 14. 보호 모드와 필수 무결성 제어(MIC: Mandatory Integrity Control) [3]파일 다운로드1
432정성태1/10/200725387Windows: 13. InitOnceExecuteOnce API 소개 [5]
431정성태1/8/200722865Windows: 12. 비스타는 안전한 윈도우인가? [2]
430정성태1/7/200728969웹: 6. IIS 7 마이그레이션 정리 - Sysnet
427정성태12/30/200619487Team Foundation Server: 14. VS.NET IDE에 통합된 TFS Annotate [1]
425정성태12/29/200623402Windows: 11. Vista IIS 7(Integrated mode)에서의 ASP.NET F5 디버깅 방법
424정성태12/29/200621573기타: 16. 첫걸음 [2]
426정성태12/30/200620147    답변글 기타: 16.1. 예외 발생
420정성태12/27/200624896Windows: 10. Internet Explorer 7.0 호환성 백서 (Word 문서, 1.92MB) [7]파일 다운로드1
419정성태12/25/200626505Windows: 9. VS.NET 2005 원격 디버깅 구성
418정성태12/25/200634604웹: 5. IIS 7에서 클라이언트 측 인증서 사용 시 주의점 [2]
417정성태12/24/200627064Windows: 8. VS.NET 2005에서의 웹 애플리케이션 디버깅 설정
416정성태1/31/200727215오류 유형: 23. MSI 설치 시 로그 파일 생성하는 레지스트리 설정 [3]
415정성태12/31/200630966개발 환경 구성: 20. 인증서 오류 체크 목록
413정성태12/20/200627746VC++: 26. volatile 키워드 [1]파일 다운로드1
412정성태12/17/200631688오류 유형: 22. VS.NET 2005 SP1 설치 도중 오류 [9]
411정성태12/16/200620717오류 유형: 21. TFS SP1 설치 관련 오류 (2) - KB919156 패치 이후 TFS 접근 문제
410정성태12/16/200621967오류 유형: 20. TFS SP1 설치 관련 오류 (1) - KB919156 패치
... 181  182  [183]  184  185  186  187  188  189  190  191  192  193  194  195  ...