====== MS-SQL 파일관리 ====== ===== 파일정책 ===== - MSSQL은 데이타파일(mdf)과 트랜잭션로그파일(ldf) 로 구성되어 있습니다. - mdf 파일은 데이타베이스에 저장되는 실데이타를 의미합니다. - ldf 파일은 데이타를 이용한 읽기,쓰기,수정,삭제 등의 모든 로그를 기록합니다. - 특정데이타에 대한 입출력 작업이 반복되면, ldf 파일이 mdf 파일에 비해 엄청나게 커질 수 있습니다. \\ 이런 경우는 주로 잘못된 프로그래밍 또는 오류로 인한 무한루프에 의해 급증하는 경우도 있으므로 확인해 보셔야 합니다. ===== 복구정책 ===== - mdf 파일만 가지고도 복구가 가능합니다. \\ 하지만 권장하지는 않습니다. - 기본정책은 ldf 용량을 줄여가면서 백업파일을 가지고 계셔야 합니다. ===== ldf 파일사이즈 줄이기 ===== - admindb 라는 데이타베이스가 있다고 가정하고 이야기 하겠습니다. - 디비를 선택합니다. use admindb - 로그파일 정보를 확인합니다. dbcc loginfo - 데이타베이스가 사용하는 mdf,ldf 파일경로,이름,크기를 확인합니다. exec sp_helpfile - 디이타베이스가 사용하는 로그를 백업합니다. backup Log admindb to disk='c:\dbbackup\admindb.20080124.bak' - 트랜잭션 로그파일을 최소의 단위로 축소합니다. backup log admindb with truncate_only - 트랜젹션 로그파일을 삭제합니다. backup log admindb with no_log - 트랜잭션 로그파일을 20M로 생성합니다. \\ 일반적으로 **DB명_log** 로 기술된다. dbcc shrinkfile(admindb_log,20) - mdf, ldf 파일의 resizing을 확인합니다. exec sp_helpfile ===== 고급팁 ===== ==== 트랜잭션 로그파일 최대값 설정 ==== - 갑작스러운 트랜잭션 로그파일의 증가로 문제가 되는 것을 방지하기 위해서 트랜잭션 로그파일의 최대크기를 지정해 놓습니다. - 아래의 명령을 수행하면 트랜잭션 로그는 200M를 한계치로 생성->삭제됩니다. - 트랜잭션로그의 용량은 데이터의 중요도 및 규모에 따라 정책적으로 유지하셔야 하는 부분입니다. alter database admindb modify file ( name = admindb_log, maxsize = 200mb ) go ==== shrinkdatabase 명령 ==== - admindb 데이타베이스를 파일에 2%의 여유공간이 남도록 크기를 줄이는 예제이다. dbcc shrinkdatabase(admindb,2,truncateonly)