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

1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5810이건우1/31/202311824윈도우서비스를 통한 웹통신관련 질문입니다 [3]
5809이상훈1/31/202312225다채널 영상 디스플레이어 개발 관련 질문입니다. [3]
5808근우1/30/202312155WPF 에서 UserControl 과 ControlTemplate 의 차이점은 무엇인가요? [6]
5807궁금맨1/28/202314648C# 10 책에 나온 예제의 결과가 제 컴에서는 좀 달라서요. 이유가 궁금합니다. [1]
5806스레드1/25/202311259총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
5805어웨이트1/25/202311236Taskcontinuewith vs Async/Await [2]파일 다운로드1
5804나이많은...1/25/202310800MS의 Dependency Injection(DI)에 AddSingleton으로 등록된 객체의 Event 등록후 사용시 앱 종료시 별도로 Event를 해지해야 하나요? [2]
5803dssc...1/24/202311662드라이브 문자를 통해서 물리 디스크 명칭을 알아내고 싶습니다. [1]
5802모바일앱1/22/202312242XAMARINE vs Android Studio [7]
5801블루투스1/19/202312818WPF 은행지폐계수기 개조 후 결과값 서버 전송 [2]파일 다운로드1
5800김민아1/19/202313030안녕하세요 가비지 컬렉터 동작 원리 중 궁금한점이 있습니다 [5]
5799guest1/19/202311849C# 공유폴더 내 Acess 디비 공유 [2]
5798kss1/19/202310731책 오탈인가요? [1]
5797이거비버1/19/202310425C# 공부 이후 MS 프레임워크.. 어느것을 공부해야할까요? 너무 많아서 정신이 없네요 [5]
5796guest1/19/202310450해킹 test [3]
5795동기1/18/20239578동기 스레드와 메서드와 While [2]
5794박규동1/18/20239719.net publish 할때마다 runtimeconfig 값이 바뀌는 현상 [1]
5793후후훗1/18/202310235.NET Core 에서 사용중인 함수 후킹 방법 [2]
5792Will...1/18/202310450소스코드 Log Write 기능을 리스트업 질문 [9]
5791PLC1/16/202310673C# - 실시간 5개 룸 모니터링 [15]
5790집으로 ...1/13/202310680[UI 멈춤 현상]deadlock 관련 글을 보고 혹시나 하고 문의 드립니다. [4]
5789guest1/10/202310441스레드와 Async Task [2]파일 다운로드1
5788kr11/10/202310893C# 에서 제공하는 컬렉션들의 차이점이 궁금합니다. [3]
5787stack1/10/202310910STACKOVERFLOW [1]
5786Dev ...1/9/202312759익명 클래스 말고 익명 구조체는 불가능한걸까요? [4]
5785음성인식1/8/202312521음성인식 System.Speech - 문법에 사용된 언어가 음성 인식기의 언어와 일치하지 않습니다. [2]
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...