SQL Server 데이터베이스 디스크 드라이브 조각 모음
이 문서에서는 SQL Server 데이터베이스 드라이브 조각 모음에 대한 몇 가지 지침을 제공합니다.
원래 제품 버전: SQL Server
원래 KB 번호: 3195161
운영 체제 계층에서 SQL Server 디스크를 조각 모음해야 하나요?
이는 현재 드라이브의 조각화 상태에 따라 달라집니다. 일반적으로 SQL Server 데이터베이스 드라이브 조각 모음 섹션에 설명된 예방 조치를 따른다고 가정하면 손상되지 않으며 도움이 될 수 있습니다. 유일한 부정은 조각 모음 도구가 트랜잭션 데이터 기능을 지원하지 않는 한 SQL Server 를 종료해야 한다는 것입니다. 좋은 소식은 조각 모음을 실행한 후에 디스크에서 많은 자동 증가 및 기타 파일이 이동하지 않는 한 다시 수행할 필요가 없다는 것입니다. 유틸리티에서 사용하는 쓰기 캐싱 전략을 이해해야 합니다. 이러한 유틸리티에 의한 캐싱에는 배터리가 지원되지 않는 캐시가 포함될 수 있으며 이는 WAL 프로토콜 요구 사항을 위반할 수 있습니다.
자세한 정보
디스크 조각 모음은 데이터베이스 파일을 포함한 모든 파일을 하드 디스크의 연속 클러스터로 이동합니다. 이렇게 하면 파일 액세스가 최적화되고 속도가 향상됩니다. Windows NT 운영 체제를 제외하고 하드 디스크를 조각 모음하지 않으면 운영 체제가 데이터베이스 파일을 검색하기 위해 디스크의 여러 물리적 위치로 이동해야 파일 액세스 속도가 느려질 수 있습니다.
물리적 데이터 액세스는 I/O 요청에서 가장 비용이 많이 드는 부분이기 때문에 조각 모음은 SQL Server 및 기타 애플리케이션에 성능 향상을 제공할 수 있습니다. 서로 가까운 데이터의 위치 지정 관련 청크는 I/O 작업 요구 사항을 줄입니다.
다양한 조각 모음 유틸리티는 현재 시장에서 사용할 수 있습니다. 일부 유틸리티는 열려 있는 파일에서 조각 모음을 사용하도록 설정하는 반면, 다른 유틸리티는 닫힌 파일 조각 모음이 필요하거나 닫힌 파일 조건에서 사용할 때 더 나은 성능을 제공합니다. 또한 일부 유틸리티에는 트랜잭션 기능이 있지만 다른 유틸리티는 그렇지 않습니다.
SQL Server 데이터베이스 드라이브를 조각 모음할 때의 주의 사항
SQL Server에서 사용할 조각 모음 유틸리티를 평가할 때 유틸리티가 트랜잭션 데이터 기능을 제공하는지 확인합니다. 특히 다음과 같은 트랜잭션 데이터 기능을 제공하는 조각 모음 유틸리티를 선택합니다.
원래 섹터는 새 섹터가 성공적으로 설정되고 데이터가 성공적으로 복사될 때까지 이동된 것으로 간주되지 않습니다.
이 유틸리티는 파일을 논리적으로나 물리적으로 그대로 유지하는 안전한 방법으로 정전과 같은 시스템 오류로부터 보호합니다. 데이터 무결성을 보장하기 위해 조각 모음 유틸리티가 SQL Server 기반 파일에서 실행 중인 경우 플러그 풀(pull-the-plug) 테스트를 사용하는 것이 좋습니다.
WAL(Write-Ahead Logging) 프로토콜을 사용하려면 데이터 손실을 방지하기 위해 섹터 재작성을 방지해야 합니다. 유틸리티는 데이터 이동을 수행하는 한 파일의 물리적 무결성을 유지해야 합니다. 이 유틸리티는 트랜잭션 방식으로 섹터 경계에서 작동하여 SQL Server 파일을 그대로 유지해야 합니다.
유틸리티는 파일이 수정에 대해 일관된 이미지를 유지하도록 보장하는 적절한 잠금 메커니즘을 제공해야 합니다. 예를 들어 유틸리티는 원래 섹터가 새 위치에 복사될 때 수정할 수 없도록 해야 합니다. 수정이 허용되면 조각 모음 유틸리티에서 쓰기가 손실될 수 있습니다.
이러한 트랜잭션 데이터 기능을 제공하지 않는 중요한 디스크 조각 모음은 열려 있는 데이터베이스 파일을 조각 모음하지 않도록 조각 모음할 디스크를 사용하는 SQL Server 인스턴스가 종료되지 않는 한 사용하면 안 됩니다.
오픈 파일 조각 모음은 일반적으로 닫힌 파일 조각 모음에서 다음과 같은 몇 가지 가능한 문제를 발생합니다.
파일 열기 조각 모음은 성능에 영향을 줍니다. 조각 모음 유틸리티는 파일의 섹션을 잠글 수 있으므로 SQL Server에서 읽기 또는 쓰기 작업을 완료하지 못할 수 있습니다. 이는 SQL Server를 실행하는 서버의 동시성에 영향을 줄 수 있습니다. 조각 모음 도구 제조업체에 문의하여 파일이 잠겨 있는 방식과 이것이 SQL Server 동시성에 어떤 영향을 미칠 수 있는지 알아보세요.
파일 열기 조각 모음은 쓰기 캐싱 및 순서 지정에 영향을 줄 수 있습니다. 오픈 파일 기반 유틸리티에는 I/O 경로 구성 요소가 필요합니다. 이러한 구성 요소는 쓰기 작업의 순서 또는 의도된 특성을 변경해서는 안 됩니다. 쓰기 또는 WAL 프로토콜 테넌트가 손상되면 데이터베이스 손상이 발생할 수 있습니다. 데이터베이스와 연결된 모든 파일은 단일 엔터티로 간주됩니다. (많은 Microsoft 기술 자료 문서, SQL Server 온라인 설명서 및 다양한 백서에서 다룹니다.) 모든 쓰기는 원래 쓰기 순서 시퀀스 및 쓰기-통과 기능을 유지해야 합니다.
권장 사항
- 새 데이터베이스를 만들거나 기존 데이터베이스를 볼륨으로 이동하기 전에 형식이 지정되지 않은 경우 NTFS 볼륨을 조각 모음합니다.
- 데이터베이스를 처음 만들 때 SQL 데이터 및 로그 파일을 적절하게 계획하고 크기를 조정해야 합니다.
- 자동 증가를 염두에 두고 SQL Server 2014 이전 트랜잭션 로그를 만듭니다.
- 트랜잭션 로그가 있는 디스크 또는 디스크를 조각 모음합니다. 이렇게 하면 트랜잭션 로그의 외부 파일 조각화를 방지할 수 있습니다. 이 문제는 파일에 자동 증가가 많거나 많은 데이터베이스, 로그 또는 수정된 다른 파일이 포함된 전용 디스크가 아닌 경우에 발생할 수 있습니다. 이 경우 파일(트랜잭션 로그 파일 포함)이 인터리브되고 조각화될 수 있습니다.
- 클러스터 디스크인 데이터베이스 드라이브를 조각 모음하는 경우 상태 모니터링(유지 관리 모드라고도 함)을 일시 중단하도록 클러스터 디스크를 설정해야 합니다.
- 조각화를 최소화하려면 데이터베이스 파일을 축소하지 마세요. 또한 성장 활동을 최소화하는 크기로 수동으로 확장합니다.
- 전용 디스크에 데이터베이스 파일을 유지합니다.
- SQL Server 데이터베이스 및 백업 파일이 포함된 위치를 조각 모음하기 전에 전체 백업을 수행합니다.