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

... 61  62  63  64  65  66  [67]  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
886김재영6/16/201011026스레드 선언시 (Parameterized/)ThreadStart에 정의되는 메소드의 위치에 질문이 있습니다. [3]
885장근배6/13/201018194Win32Exception 창 핸들 에러 [1]
883채동민6/10/201010639비동기 DB 쿼리관련 질문
884정성태6/10/201011951    답변글 [답변]: 비동기 DB 쿼리관련 질문
881최준영5/24/201011595load되지않은 아이템 load하는 방법? [1]
880임상일5/10/201013505VS2010 TestManager를 통한 UI Test 관련 질문입니다. [2]파일 다운로드1
879정용훈5/3/201014521wcf 인증 문제 [2]
878채동민4/20/201013690WCF에서 maxItemsInObjectGraph 오류 관련 질문드립니다. [2]
872날쌘돌이4/8/201016555Windows7 에서 IIS에서 폼인증 으로 디버깅.. [1]파일 다운로드1
871영초4/7/201011786실버라이트로 스캐너 구동 프로그램이 가능할까요? [1]
869김재영4/6/201010572이미 실행된 어셈블리 컨트롤 권한을 다른 어셈블리에서 가져올 수 있습니까? [2]
868Lime3/5/201014408WCF 에서의 DataTable 사용 [2]
867Dani...2/18/201014347Question - HTTP 401.3 on DELETE, PUT verbs [6]파일 다운로드1
865박근대2/16/201011170WCF 오류 문의. [1]
863날쌘돌이1/31/201013941ActiveX Cab에서 닷넷 dll 등록 [1]
862장근배1/28/201011224AppPolId를 알 수 있는 방법이 있는지요? [1]
864장근배2/1/201011074    답변글 [답변]: AppPolId를 알 수 있는 방법이 있는지요?
858생초보1/26/201011349안녕하세요.. 파일 생성 처리 문제로 .... [2]
857꼭지1/22/201016354How to support Basic + Windows authentication mode in WCF(RESTful service) [4]파일 다운로드2
856질의자1/13/201014967vcredist_x86 배포 관련 여쭙습니다. [1]
855임동찬1/13/201012826이벤트 핸들러와 쓰레드의 관계 2 [4]파일 다운로드2
854임동찬1/12/201012858이벤트 핸들러와 쓰레드의 관계 [1]
853장근배1/12/201012831압축 프로그램,, [1]
852임동찬1/6/201010639base.OnStart(agrs) [1]
851한귀순1/6/201016082oracle & transaction 질문 [5]
850박한주12/31/200913246COM과 C#간 권한 문제에 관해 여쭤봅니다. [5]
... 61  62  63  64  65  66  [67]  68  69  70  71  72  73  74  75  ...