Microsoft MVP성태의 닷넷 이야기
TFS 관련하여 질문드리고자 합니다. [링크 복사], [링크+제목 복사],
조회: 11371
글쓴 사람
궁금이 (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)
5910guest4/24/20233799Async 메서드와 try~catch [1]
5909guest4/22/20234317Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/20234131텅빈 원그리기 [5]
5907민성4/21/20233692안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/20233835Dispatcher 서비스 구현 질문 [1]
5905guest4/20/20234251tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/20234163[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
5903guest4/18/20233511fileSystemWatcher 이벤트 관련 질문입니다 [2]
5902guest4/17/20234219c#으로 USB 관련 질문 [2]
5901guest4/17/20233726내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [5]
5900guest4/17/20234937DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [2]파일 다운로드1
5899guest4/17/20233795Dictionary와 Linq [4]
5898차가워4/17/20233700CNTK 교육 문의 [1]
5897guest4/17/20233563Socket스레드와 UI thread [4]
5896HAN4/16/20233600c언어 return 에 대해 궁금한게 있어요. [1]파일 다운로드1
5895guest4/15/20233319Drag and Drop - 모든 컨트롤 [2]
5894송부장4/14/20234690[질문] Visual Studio 2022에서 '도구 상자 항목 선택'의 'COM 구성 요소' 탭에서 ActiveX 목록이 보이지 않습니다. [3]파일 다운로드2
5893감사합니...4/14/20233334오라클 OLEDB방식 접속 후 SELECT 'TEST' TEST_VALUE FROM DUAL의 값이 이상합니다. [1]
5892한무4/14/20233518C# 으로 백그라운드에서 워드를 실행하여 매크로 실행이 가능 할까요? [2]
5891리세4/14/20233509안녕하세요.C# 서버프로그램에서의 Mysql 쿼리문제(다중쿼리 실행)에 대해 문의드립니다. [2]
5890guest4/14/20234191C# 프리랜서로 돈 벌려면 성태님 책 마스터하면 되나요? [6]
5889전예찬4/14/20233345C# 파일 복사 관련 질문 드립니다. [3]
5888정경구4/12/20233628C# 첫 환경 세팅과 관련해서 [4]
5887HAN4/12/20233250안녕하세요 파이썬도 공유 가능 할까요? [1]
5886guest4/11/20233640필요한 어셈블리만 다운로드 및 재로딩하는 방법에 관하여 [2]
5885guest4/11/20233479c#으로 드림위버같은 거 만들어볼려는데요 [6]
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...