Microsoft MVP성태의 닷넷 이야기
TFS 관련하여 질문드리고자 합니다. [링크 복사], [링크+제목 복사],
조회: 11379
글쓴 사람
궁금이 (yupchaki at gmail.com)
홈페이지
첨부 파일
 

안녕하세요. 궁금한것이 있어 웹을 찾던 중 이곳까지 오게 되었습니다.


VSS를 이용해서 쓰다가 약 6개월전 TFS를 도입하여 사용하기 시작 했습니다.

마이그레이션은 아니고 소스만 내려받아 올리는 방식으로 사용을 했습니다.

TFS를 처음사용할때 소스의 용량이 약 3.5기가 정도 되었는데,

6개월정도 사용하다보니 실제 소스의 량의 증가는 거의 없었던데 비해(약 100메가 정도)

TfsVersionControl_backup 의 DB 사이즈가 10기가(10.4기가) 정도로 증가해 있었습니다.

서버의 사양이 그리 좋지 않고 백업의 문제로(현재 DVD로 백업합니다) DB의 사이즈가 문제가 되고 있는데,

그 증가분이 여러가지의 로그나 히스토리 인건지 아니면 소스의 복사본을 따로 만드는 건지,

어떤부분이 증가하였고, 또 어떤 부분을 확인해 봐야 할지 도통 감이 잡이지 않습니다.

단지 소스만을 관리 하여 DB의 사이즈를 줄여보고 싶은데

조금이나마 조언을 구하고 싶어 이렇게 글을 남기게 되었습니다.

(TfsVersionControl DB에 tbl_content 테이블이 약 8.5기가 정도 사용하고 있습니다.)

그럼 오늘도 즐거운 하루 보내시길 바랍니다.








[최초 등록일: ]
[최종 수정일: 2/2/2009]


비밀번호

댓글 작성자
 



2009-02-02 09시22분
이상하군요. ^^ 그 동안 전혀 그에 대해 궁금증을 가져본 적이 없었습니다.
일단, 잠시 TFS DB 를 좀 살펴 보니, tbl_Content / tbl_File 이 눈에 띕니다. tbl_Content 의 Content 필드가 binary data 를 포함하고 있고 tbl_File 의 CompressedLength/CompressionType 이라는 컬럼이 있는 것을 보면 소스 코드 파일은 압축되어 저장되는 것으로 보입니다. 압축이니... 이전파일과의 delta 에 대해서만 관리하진 않을 것 같습니다.

따라서, 1byte 만 바뀌어도 전체 파일 내용이 새롭게 저장되고 압축 효율에 따라 크기 증가는 달라질 것입니다.

그러니, 소스 량의 증가가 100MB 에 불과하다 해도 체크아웃/체크인의 빈도수에 따라 실제 DB 크기는 더 증가할 수가 있겠습니다.

일단, 소스만을 관리하여 DB 사이즈를 줄인다는 것은 소스 제어 자체를 더욱 효율적으로 하는 수 밖에는 없을 것 같습니다. 파일 자체의 크기를 줄이고(하나의 클래스에서 관리되는 코드의 양을 분할하고.) 변경된 파일에 대해서만 체크인하는 식이겠지요. (이미 그렇게 해오신다면 더 드릴 말씀이 없군요. ^^)

단... 제가 하나 조언 드릴 것이 있다면. DVD 백업은 현명하지 않은 것 같습니다.
1TB 하드가 13만원하는 시대에 DVD 로 인한 관리 시간과 DVD 자체의 가격을 생각하면 낭비라고 보입니다. 물론, 별도 보관하는 이점은 있지만, 그나마도 외장 하드라는 것이 있다는 것을 생각해 보면 DVD 로 소스 코드를 백업하는 체계는 지양되는 것이 좋을 것 같습니다.

마침 저도 최근에 읽었던 좋은 글이 있는데, 공유해 드립니다.

자동백업되는 화일서버 구축하기
; http://cafe.daum.net/Turret/Iu6n/7

귀중한 자료인 만큼, 더욱 효율적으로 안전하게 보관하시길 바랍니다. ^^
kevin25
2009-02-04 10시20분
귀한 시간 내주셔서 답변 해주신것에 대해 감사하게 생각합니다. ^^
그럼 오늘도 즐거운 하루 되세요~ ^^
yupchaki

... 16  17  [18]  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5485이재원4/17/20216602교재 315페이지 내용 질문 [3]
5484Syong4/16/202110131윈폼 기반의 응용프로그램 dll 참조와 32,64bit 빌드 관련 문의 [4]
5483한예지 donator4/15/20215708익명 형식과 var 관계 질문 있습니다. [2]
5482질문4/13/20217474WPF를 위한 MVVM toolkit 선택과 관련한 문의드립니다. [4]
5480한예지 donator4/5/20217783GetHashCode 질문있습니다! [2]
5479한예지 donator4/4/20216911Equals를 닷넷에서 어떻게 구현했는지 보고 싶을 떄는 어떻게 해야 될까요? [2]
5478갑자기C#3/23/20219401C# Winform에서 TextBox없이 입력 받을 수 있나요? [7]
5477달팽이3/18/20216337c# 도형을 그린후 편집하는 방법이 궁금합니다. [2]파일 다운로드1
5475dimo...3/2/20217260POH가 .NET 5에 추가된 것으로 알고 있습니다. POH가 유용한 경우는 어떤 경우가 있을까요? [1]
5474Syong2/26/20216770사용자 지정 컨트롤 생성시 Invalidate, Update, Refresh의 차이점 [2]
5473한예지 donator2/25/20216655디자인 타임이 뭔지 궁금합니다!! [5]
5472dimo...2/24/20217444등록하지 않고 ocx를 사용하는 `키움`관련 포스팅을 따라가다 질문드립니다. [9]
5471남산2/21/20216144MarshalDirectiveException 에 대한 질문입니다. [1]
5470한예지 donator2/7/20216062yield 질문있습니다!! [2]
5469유호성2/6/20215627Parallel + Task.Run 동시 실행 환경에서 간헐적으로 Task.Run()에서 null이 리턴됩니다. [3]파일 다운로드1
5467hero...2/4/20215980실행 환경에 따른 Thread.Sleep 딜레이 차이 질문 [8]
5466pr1/29/20215868c# winform load시 작업표시줄에 뜨지 않는 현상을 겪으신적이 있으신가요? [4]파일 다운로드1
5465영귤1/28/20216250두 번째 await 부터는 스레드 개수만 늘어나는 것이 아닌가요 [1]
5464민우1/26/20216536C# 빌드시 코드 치환되는걸 확인하는 방법 문의 [2]
5463한예지 donator1/24/20217263Parameters.AddWithValue 와 Parameters.Add 의 차이점이 궁금합니다. [2]
5462C#초보1/22/20217541사용자 정의 메시지 전달이 가능한가요? [2]
5461한예지 donator1/22/20216937AsEnumerable() 메서드 질문 있습니다! [2]
5459한예지 donator1/21/20216255typeof와 GetType의 차이점 질문있습니다. [2]
5458진우1/20/20217158C# DataTable 에 SQL 쿼리문을 실행하는 방법 문의 (LINQ 사용하지 않고) [6]
5456성민1/17/202175619.0 출간 계획이 있으신가요? [2]
5455한예지 donator1/16/20216628교재 194페이지 콜백메서드 질문 있습니다! [5]
... 16  17  [18]  19  20  21  22  23  24  25  26  27  28  29  30  ...