Microsoft MVP성태의 닷넷 이야기
TFS 에서 공통 Assembly 공유 방법에 대해서 해결책이 없을까요? [링크 복사], [링크+제목 복사],
조회: 10313
글쓴 사람
선무당
홈페이지
첨부 파일
 

Main 이라는 팀프로젝트에 Common 이라는 폴더가 있습니다. 이 폴더에서 빌드된 dll 들을 여러 팀프로젝트에서 공유를 해서 사용하게 하려고 합니다.
소스코드를 공유하는건 아닙니다.
그리고 Main 을 관리하는 팀에서 Common 에 들어있는 dll 의 버전이 변경되면(프로젝트의 내용이 변경되서) 이걸 참조하는 다른 팀프로젝트에
변경 내용이 자동으로 반영되게 하려고 합니다.

구글링을 해보니 브랜치를 하면 된다고 하는거 같은데 이 경우는 dll 이 변경될 경우 변경내용이 참조하고 있는 팀 프로젝트들에게 반영이 되지 않는거
같더군요.

어떻게 구성하면 될까요?
내용이 많으면 관련 내용이 있는 사이트라도 없을까요?








[최초 등록일: ]
[최종 수정일: 1/11/2012]


비밀번호

댓글 작성자
 



2012-01-11 11시11분
TFS Dependency Replicator 와 같은 도구들이 그와 같은 문제에 대한 해결을 시도했던 것 같은데, 그다지 인기가 없었던 것 같습니다.

Getting Started with TFS Dependency Replicator
; http://notgartner.wordpress.com/2007/12/14/getting-started-with-tfs-dependency-replicator/

아마 현재의 TFS 2010 버전에는 맞지 않을 것 같지만, 소스 코드는 공개되어 있으니 시간 나실 때 참고하시는 것도 나쁘진 않겠지요. ^^ (사실, 저도 사용해 본 적은 없습니다.)

저 개인적으로도 이 부분에 대해 고민을 해 본적이 있는데요. 사실, '무조건' 업데이트 되는 것은 방법이 아니라는 결론에 다다르게 되었습니다. 왜냐하면, 하위 호환성을 맞추는 것은 무척이나 까다로운 제약 조건이기 때문에 대단한 공개 API 가 아니고서는 하위 호환성은 수시로 깨기 마련입니다.

현실적으로 볼 때는, 특정 버전의 빌드까지 언제든 구할 수 있으면 만족되는 것이 좋고, DLL 을 최신 버전으로 업데이트 하는 경우는 대개 '팀장' 급의 사람이 한명만 새로운 DLL 을 다운로드 받아서 팀 프로젝트에 포함시키는 수고 정도만 해주는 것으로 해결할 수 있기 때문입니다.

이러한 방식이라면, 회사 자체적으로 Private Nuget 배포관리를 만들어보는 것도 좋은 대안이 될 수 있습니다.
아래 2개의 글을 보시면 NuGet에 대한 감을 잡는 데 어렵지 않을 것입니다.

Manage Project Libraries with NuGet
; http://msdn.microsoft.com/en-us/magazine/hh547106.aspx

Becoming a NuGet Author
; http://msdn.microsoft.com/en-us/magazine/hh708753.aspx

언제 시간나면... 말씀하신 그 주제에 대해서도 한번 글을 써봐야겠군요. ^^
정성태
2012-01-12 12시53분
[선무당] 항상 친절한 답변 감사드립니다. 기회가 되면 한번 만나서 이런 저런 얘기도 듣고 싶네요.
말씀하시것처럼 하위 호환성 문제를 고민하지 않은것은 아닙니다. 그런데 PL 이 배포를 하는것도 경험상
공유하는 플젝트들이 많아지니 버전관리의 일관성이 상당히 어렵습니다. 거의 일관성을 포기하게 되더군요.
이런 상황에 대한 문제점도 적지가 않더군요.
그래서 이번에는 하위 호환성 보다는 일관성에 무게를 두고 진행해 보려고 합니다.
그리고 부탁사항인데 향후 TFS 와 MS Project Server 를 연동해서 프로젝트 일정 관리하는 것에 대해서도
한번 글을 써 주시면 감사하겠습니다.
 
[guest]

1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5648주니어개...4/13/20223930컴파일된 코드를 원시코드로 바꾸려면 어떻게해야하나요? [1]파일 다운로드1
5647장성욱4/7/20223972코어지정 CPU사용률 관련 질문 [1]
5646서형주4/6/20223990List에 여러개의 class 객체를 만들어 넣을때, 객체의 method들도 같이 생성되어 메모리를 차지하나요? [1]
5645김인태4/6/20223638윈도우즈 서버의 AD 계정 생성 조건이 있을까요? [1]
5644ㅇㅇ4/6/20224379c# 프로그램을 이용하여 리눅스상에 파일 생성이 가능한가요? [1]
5643유필재4/5/20224263TCP클라이언트 연결 및 통신관련하여 문의드려요 [1]
5642차가워4/4/20224514UdpClient 패킷 수신 문의 [4]
5641장성욱4/4/20224931코어 할당 및 cpu 부하테스트 질문 [7]
5640icoo...4/4/20224464웹가든에서 메모리 동적 업데이트 방법 [1]
5639차가워4/4/20224356c++ 서버 c# 클라이언트 호환 문의 [1]
5638초급4/3/20224655c# sql server 연동 [1]
5637따봉이4/1/20224926Winform Form Load 후 자동 캡쳐관련 [1]파일 다운로드1
5636김철순3/31/20224909WPF에서 Richtext의 View 문의 [5]
5635guest3/30/20224939안정적인 pinning이 가능하네요. [3]파일 다운로드1
5633꿀주세요3/30/20224577선생님 마우스 클릭이벤트 질문이 있습니다. [4]
5632김현수3/30/20224919Remote Desktop으로 접속시 WPF UI 가 다시 그려지는 이벤트를 막을 수 없을까요? [3]
5631김기헌3/24/20224557WPF 컨트롤의 그래픽 처리관련 질문드립니다 [2]파일 다운로드1
5630장성욱3/24/20224371로깅관련 질문입니다. [2]
5629감사합니...3/23/20224633함수에서 예외가 발생하면 try ~ catch처리기를 찾을 때 까지 상위 함수로 계속 올라가나요? [2]
5628홍길동3/23/20225290질문드립니다. [2]파일 다운로드1
5626연준혁3/21/20224489안녕하세요. [3]
5625jaew...3/18/20225420c# 8.0 도서를 구입한 사람입니다. [1]
5624초보자3/17/20224390람다 캡처 관련 문의 [2]
5623한예지 donator3/15/20224758인터프리터 원리가 궁금합니다. [4]
5622김민아3/8/20224708const와 readonly의 명확한 차이가 이게 맞나요? [2]
5621장성욱3/8/20224515c# 로그 관련 질문 [1]
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...