Microsoft MVP성태의 닷넷 이야기
TFS 관련하여 질문드리고자 합니다. [링크 복사], [링크+제목 복사],
조회: 11277
글쓴 사람
궁금이 (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

... 31  32  33  34  35  36  37  38  39  [40]  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4854heyh...7/6/20179663
4853heyh...7/5/20179769성태님이 작성한대로 해봤습니다. [1]파일 다운로드1
4852김레오7/4/201711895서드파티 dll 디버깅에 대해 질문드립니다. [2]
4851김현준7/3/201711066Datagridview VirtualMode 시 GC가 계속 호출되는 현상이 이해가 안갑니다. [2]
4850heyh...7/3/201710798성태님 밑에 질문드렸던 오류입니다. [1]파일 다운로드1
4849포플러7/2/201729490C#으로 만든 프로그램이 어느 순간 속도가 느려지거나 멈춤현상이 있습니다. [4]
4848윤진영7/2/201712410Microsoft Visual C++ 6.0 무설치 관련 [1]
4847heyh...6/30/201710394아무리 고민해도 답이 안나와서.. 질문 드립니다 [1]
4846heyh...6/28/201710450Clickonce에서 Clickonce로 변수 전달 [1]
4845heyh...6/26/201710090vb.net 에서 manifest 제거 방법 [1]파일 다운로드1
4844san6/21/20179564part3 pdf파일로 보는데 눈아퍼요.... 활자로 보고싶어요 [2]
4843윤현수6/20/20179806socket통신에 관한 질문입니다. [1]
4842오세운6/7/201710502로그인폼 다시 질문드려요. [1]
4841popo6/7/201710265궁금한사항이 있어 질문 드립니다. [1]
4840윤현수6/5/201710267datagridview에 바인딩시킨 dataset.table에 관련된 질문입니다. [2]파일 다운로드1
4839오세운6/2/201711176로그인폼 만들기 [1]
4838후배5/29/201711909PDF Reader 라이브러리.. [3]
4837KDP5/29/201711405c++ to C# 컨버팅 문의 [2]
4836popo5/26/201714541리플렉션 성능 관련 질문 드립니다. [2]
4835guest5/25/201710275wpf Canvas 질문드립니다. [1]
4834부탁드립...5/19/201711175익스체인지 서버 구동중 인증서를 받는 과정에서오류가 납니다 [1]
4833안종윤5/18/201711561winform을 Web Browser에 붙일 수 있는지요? [1]
4832guest5/17/201711042c# UDP socket예제 실행방법 [3]
4831guest5/15/201713468WPF .net 3.5에서 TextBox 한글 문제 [3]
4830초보자5/7/201718357프로그램 비정상 종료 메시지 창 없애는 방법 [4]
4829윤현수4/26/201714744System.Text.Encoding 질문 [1]
... 31  32  33  34  35  36  37  38  39  [40]  41  42  43  44  45  ...