Microsoft MVP성태의 닷넷 이야기
Team Foundation Server: 48. TFS - Team Project Collection 이전하는 방법 [링크 복사], [링크+제목 복사]
조회: 17182
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

TFS - Team Project Collection 이전하는 방법

TFS의 "Team Project Collection"은 이전이 가능합니다. 예를 들어, 기존에 운영되던 TFS 2010 을 그대로 둔 체 TFS 2012를 새로 설치한 경우를 생각해 보면, 기존 TFS 2010 에 있던 Project Collection들을 새롭게 설치한 TFS 2012에 옮겨야 할 수 있습니다. (물론, 업그레이드 하는 것이 더 편하지만!)

방법도 그리 어렵지는 않습니다. 우선, 소스가 되는 TFS 에서 해당 "Team Project Collection"을 분리(Detach)하는 것으로 시작합니다.

tfs_collection_mig_1.png

분리 작업이 완료되기 전에 "Verify" 버튼으로 유효성 검사를 할 수 있는데요. 만약, 여러분들이 쓰는 TFS 가 "SQL Server 2008 (이상) Enterprise" 버전을 쓰고 있다면 이 과정에서 다음 화면과 같이 경고가 하나 뜰 수 있습니다.

tfs_collection_mig_2.png

만약 경고 메시지가 다음과 같고,

This collection has SQL Enterprise features enabled. If you are moving the collection across SQL Server Editions please read the documentation (http://go.microsoft.com/fwlink/?LinkId=166007) to see how this impacts you.


여러분들이 이전하려는 대상 TFS 서버가 "Enterprise" 버전 이외의 SQL 서버를 사용한다면 압축 옵션을 해제해 주어야 합니다. 이에 대해서는 별도로 정리해 두었으니 참고하세요.

Database '...' already exists. Choose a different database name. (Microsoft SQL Server, Error: 1801)
; https://www.sysnet.pe.kr/2/0/1331

경고와 상관없이 진행은 그대로 할 수 있고 분리 작업은 성공적으로 완료됩니다.

tfs_collection_mig_3.png




분리된 Team Project Collection을 붙이는 작업은 분리했던 것과 반대로 진행하면 됩니다.

예제의 Team Project Collection 이름이 "TestCollection"이기 때문에 데이터베이스 파일은 "Tfs_TestCollection.mdf", "Tfs_TestCollection_log.ldf" 파일이 됩니다. 이 파일들을 대상 TFS 서버가 사용하는 SQL 서버가 설치된 컴퓨터에 복사하고, SSMS 관리도구를 이용하여 SQL 서버에 연결(attach)합니다.

그런 다음 "Team Foundation Server Express Administration Console"을 실행하고 "Team Project Collections" 노드에서 "Attach Collection" 링크를 선택합니다.

tfs_collection_mig_4.png

그럼, 다음과 같이 창이 뜨고 목록에는 현재 TFS 에는 존재하지 않는 Team Project Collection 을 자동으로 보여줍니다.

tfs_collection_mig_5.png

"Verify" 버튼을 눌러서 유효성 검사를 하고 통과하면 "Attach" 버튼을 누르는 것으로 Collection 이전 작업이 완료됩니다.

(혹시나 궁금하신 분들이 있을지도 몰라서 미리 말씀드리면, "Detach/Attach" 과정은 반드시 필요합니다. 예를 들어, 단순하게 mdf/ldf 파일만 복사해서 다른 TFS에서 attach 시키려 해도 아예 DB 목록에서 해당 DB는 나타나지 않습니다.)




제 경우에는 실습을 TFS 2010 에서 TFS 2012 Express로 이전을 해봤습니다.

이런 경우에 SharePoint를 사용했던 Team Project가 있다면 해당 Collection을 attach시킬 때, 다음과 같은 경고가 발생합니다.

[2012-08-23 01:53:58Z][Warning] 
Exception Message: TF30063: You are not authorized to access http://testpc:17012/_vti_bin/TeamFoundationIntegrationService.asmx. (type TeamFoundationServerUnauthorizedException)
Exception Stack Trace:    at Microsoft.TeamFoundation.Client.Channels.TfsHttpWebRequest.SendRequest()
   at Microsoft.TeamFoundation.Client.Channels.TfsHttpRequestChannel.Request(TfsMessage message, TimeSpan timeout)
   at Microsoft.TeamFoundation.Client.Channels.TfsHttpClientBase.Invoke(TfsClientOperation operation, Object[] parameters, TimeSpan timeout, Object[]& outputs)
   at Microsoft.TeamFoundation.Client.Channels.TfsHttpClientBase.Invoke(TfsClientOperation operation, Object[] parameters, Object[]& outputs)
   at Microsoft.TeamFoundation.Admin.SharePointConfigurationHelper.ValidateAutoconfigureWebApplication(Uri adminUrl, Uri siteUrl, ITFLogger logger)
... [이하 생략] ...

상관없습니다. TFS Express에는 SharePoint가 없기 때문에 발생하는 것이니 무시해도 좋습니다.




마지막으로 한가지 더 시행착오를 말씀드리면, "Team Project Collection"을 이전한 후 Team Explorer에서는 기존 프로젝트 들에 대해서 "Workspace"의 경로 매핑을 하려 할 때 다음과 같은 오류가 발생할 수 있습니다.

The working folder ... is already in use by the workspace ...;... on computer ...

이 오류에 대해서는 웹에서 검색해 보면 다양한 사례들이 나오는데요. 일단 제 경우에는 재현 시나리오가 다음과 같습니다.

  1. A컴퓨터에서 T1 TFS 서버로 접속했었고,
  2. A컴퓨터의 운영체제를 새로 설치하고 Team Explorer를 새로 설치하고,
  3. A컴퓨터에 T2 TFS를 설치하고,
  4. T1 TFS의 Team Project Collection을 T2 TFS 로 이전하고,
  5. A컴퓨터에서 이전된 바로 그 Team Project Collection에 연결하려 할 때!

따라서 이 오류를 해결하기 위해서는 이전 바인딩 정보를 해제해야 하는데요. 이를 위한 별도의 명령은 없고, 직접 DB를 열어서 "tbl_WorkingFolder" 의 WorkspaceId 와 tbl_Workspace 의 WorkspaceId 값을 찾아내서 이전 값들을 보관하고 있는지 확인하고, 바로 그 이전 WorkspaceId값들을 가진 데이터를 tbl_WorkingFolder에서 삭제해 주면 됩니다.

사실, 위와 같은 경우가 발생할 수 있는 확률이 낮으므로... 이 정도 설명으로 마치겠습니다. ^^





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







[최초 등록일: ]
[최종 수정일: 8/24/2012]

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)
13458정성태11/26/20232360닷넷: 2170. .NET Core/5+ 기반의 COM Server를 tlb 파일을 생성하는 방법(tlbexp)
13457정성태11/25/20232295VS.NET IDE: 187. Visual Studio - 16.9 버전부터 추가된 "Display inline type hints" 옵션
13456정성태11/25/20232601닷넷: 2169. C# - OpenAI를 사용해 PDF 데이터를 대상으로 OpenAI 챗봇 작성 [1]파일 다운로드1
13455정성태11/25/20232492닷넷: 2168. C# - Azure.AI.OpenAI 패키지로 OpenAI 사용파일 다운로드1
13454정성태11/23/20232843닷넷: 2167. C# - Qdrant Vector DB를 이용한 Embedding 벡터 값 보관/조회 (Azure OpenAI) [1]파일 다운로드1
13453정성태11/23/20232342오류 유형: 879. docker desktop 설치 시 "Invalid JSON string. (Exception from HRESULT: 0x83750007)"
13452정성태11/22/20232446닷넷: 2166. C# - Azure OpenAI API를 이용해 사용자가 제공하는 정보를 대상으로 검색하는 방법파일 다운로드1
13451정성태11/21/20232575닷넷: 2165. C# - Azure OpenAI API를 이용해 ChatGPT처럼 동작하는 콘솔 응용 프로그램 제작파일 다운로드1
13450정성태11/21/20232382닷넷: 2164. C# - Octokit을 이용한 GitHub Issue 검색파일 다운로드1
13449정성태11/21/20232459개발 환경 구성: 688. Azure OpenAI 서비스 신청 방법
13448정성태11/20/20232699닷넷: 2163. .NET 8 - Dynamic PGO를 결합한 성능 향상파일 다운로드1
13447정성태11/16/20232580닷넷: 2162. ASP.NET Core 웹 사이트의 SSL 설정을 코드로 하는 방법
13446정성태11/16/20232533닷넷: 2161. .NET Conf 2023 - Day 1 Blazor 개요 정리
13445정성태11/15/20232849Linux: 62. 리눅스/WSL에서 CA 인증서를 저장하는 방법
13444정성태11/15/20232606닷넷: 2160. C# 12 - Experimental 특성 지원
13443정성태11/14/20232632개발 환경 구성: 687. OpenSSL로 생성한 사용자 인증서를 ASP.NET Core 웹 사이트에 적용하는 방법
13442정성태11/13/20232451개발 환경 구성: 686. 비주얼 스튜디오로 실행한 ASP.NET Core 사이트를 WSL 2 인스턴스에서 https로 접속하는 방법
13441정성태11/12/20232767닷넷: 2159. C# - ASP.NET Core 프로젝트에서 서버 Socket을 직접 생성하는 방법파일 다운로드1
13440정성태11/11/20232437Windows: 253. 소켓 Listen 시 방화벽의 Public/Private 제어 기능이 비활성화된 경우
13439정성태11/10/20232971닷넷: 2158. C# - 소켓 포트를 미리 시스템에 등록/예약해 사용하는 방법(Port Exclusion Ranges)파일 다운로드1
13438정성태11/9/20232582닷넷: 2157. C# - WinRT 기능을 이용해 윈도우에서 실행 중인 Media App 제어
13437정성태11/8/20232757닷넷: 2156. .NET 7 이상의 콘솔 프로그램을 (dockerfile 없이) 로컬 docker에 배포하는 방법
13436정성태11/7/20232983닷넷: 2155. C# - .NET 8 런타임부터 (Reflection 없이) 특성을 이용해 public이 아닌 멤버 호출 가능
13435정성태11/6/20232908닷넷: 2154. C# - 네이티브 자원을 포함한 관리 개체(예: 스레드)의 GC 정리
13434정성태11/1/20232687스크립트: 62. 파이썬 - class의 정적 함수를 동적으로 교체
13433정성태11/1/20232399스크립트: 61. 파이썬 - 함수 오버로딩 미지원
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...