Microsoft MVP성태의 닷넷 이야기
Team Foundation Server: 48. TFS - Team Project Collection 이전하는 방법 [링크 복사], [링크+제목 복사],
조회: 23374
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12663정성태6/9/202117672.NET Framework: 1065. Windows Forms - 속성 창의 디자인 설정 지원: 문자열 목록 내에서 항목을 선택하는 TypeConverter 제작파일 다운로드1
12662정성태6/8/202115412.NET Framework: 1064. C# COM 개체를 PIA(Primary Interop Assembly)로써 "Embed Interop Types" 참조하는 방법파일 다운로드1
12661정성태6/4/202127415.NET Framework: 1063. C# - MQTT를 이용한 클라이언트/서버(Broker) 통신 예제 [4]파일 다운로드1
12660정성태6/3/202118140.NET Framework: 1062. Windows Forms - 폼 내에서 발생하는 마우스 이벤트를 자식 컨트롤 영역에 상관없이 수신하는 방법 [1]파일 다운로드1
12659정성태6/2/202119029Linux: 40. 우분투 설치 후 MBR 디스크 드라이브 여유 공간이 인식되지 않은 경우 - Logical Volume Management
12658정성태6/2/202116814Windows: 194. Microsoft Store에 있는 구글의 공식 Youtube App
12657정성태6/2/202117616Windows: 193. 윈도우 패키지 관리자 - winget 설치
12656정성태6/1/202115932.NET Framework: 1061. 서버 유형의 COM+에 적용할 수 없는 Server GC
12655정성태6/1/202114588오류 유형: 722. windbg/sos - savemodule - Fail to read memory
12654정성태5/31/202115254오류 유형: 721. Hyper-V - Saved 상태의 VM을 시작 시 오류 발생
12653정성태5/31/202118505.NET Framework: 1060. 닷넷 GC에 새롭게 구현되는 DPAD(Dynamic Promotion And Demotion for GC)
12652정성태5/31/202115965VS.NET IDE: 164. Visual Studio - Web Deploy로 Publish 시 암호창이 매번 뜨는 문제
12651정성태5/31/202116160오류 유형: 720. PostgreSQL - ERROR: 22P02: malformed array literal: "..."
12650정성태5/17/202115483기타: 82. OpenTabletDriver의 버튼에 더블 클릭을 매핑 및 게임에서의 지원 방법
12649정성태5/16/202117687.NET Framework: 1059. 세대 별 GC(Garbage Collection) 방식에서 Card table의 사용 의미 [1]
12648정성태5/16/202116444사물인터넷: 66. PC -> FTDI -> NodeMCU v1 ESP8266 기기를 UART 핀을 연결해 직렬 통신하는 방법파일 다운로드1
12647정성태5/15/202116717.NET Framework: 1058. C# - C++과의 연동을 위한 구조체의 fixed 배열 필드 사용파일 다운로드1
12646정성태5/15/202115512사물인터넷: 65. C# - Arduino IDE의 Serial Monitor 기능 구현파일 다운로드1
12645정성태5/14/202115570사물인터넷: 64. NodeMCU v1 ESP8266 - LittleFS를 이용한 와이파이 접속 정보 업데이트파일 다운로드1
12644정성태5/14/202116835오류 유형: 719. 윈도우 - 제어판의 "프로그램 및 기능" / "Windows 기능 켜기/끄기" 오류 0x800736B3
12643정성태5/14/202116781오류 유형: 718. 서버 유형의 COM+ 사용 시 0x80080005(Server execution failed) 오류 발생
12642정성태5/14/202118502오류 유형: 717. The 'Microsoft.ACE.OLEDB.12.0' provider is not registered on the local machine.
12641정성태5/13/202117310디버깅 기술: 179. 윈도우용 .NET Core 3 이상에서 Windbg의 sos 사용법
12640정성태5/13/202120902오류 유형: 716. RDP 연결 - Because of a protocol error (code: 0x112f), the remote session will be disconnected. [1]
12639정성태5/12/202117308오류 유형: 715. Arduino: Open Serial Monitor - The module '...\detection.node' was compiled against a different Node.js version using NODE_MODULE_VERSION
12638정성태5/12/202117557사물인터넷: 63. NodeMCU v1 ESP8266 - 펌웨어 내 파일 시스템(SPIFFS, LittleFS) 및 EEPROM 활용
... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...