server memory 옵션
업데이트: 2006년 4월 14일
min server memory 및 max server memory의 두 가지 서버 메모리 옵션을 사용하여 Microsoft SQL Server 인스턴스에서 사용하는 버퍼 풀의 메모리 양(MB)을 다시 구성할 수 있습니다.
기본적으로 SQL Server는 사용할 수 있는 시스템 리소스에 따라 메모리 요구 사항을 동적으로 변경할 수 있습니다. min server memory의 기본 설정은 0 이고 max server memory의 기본 설정은 2147483647입니다. max server memory에 지정할 수 있는 최소 메모리 양은 16MB입니다.
[!참고] max server memory를 최소값으로 설정하면 SQL Server 성능이 심각하게 손상되며 SQL Server를 시작하지 못할 수도 있습니다. 이 옵션을 변경한 후 SQL Server를 시작할 수 없으면 -f 시작 옵션을 사용하여 SQL Server를 시작하고 max server memory를 이전 값으로 다시 설정합니다. 자세한 내용은 SQL Server 서비스 시작 옵션 사용을 참조하십시오.
SQL Server가 동적으로 메모리를 사용하면 주기적으로 시스템을 쿼리하여 사용할 수 있는 실제 메모리 양을 확인합니다. Microsoft Windows 2000의 SQL Server에서는 서버 활동에 따라 버퍼 캐시를 늘렸다 줄였다 하여 사용 가능한 실제 메모리를 4MB에서 10MB 사이로 유지합니다. 사용 가능한 메모리를 이 수준으로 유지 관리하면 Windows 2000에서 페이징을 방지합니다. 사용 가능한 메모리가 이보다 적은 경우 SQL Server는 메모리를 Windows 2000으로 해제합니다. 사용 가능한 메모리가 이보다 많은 경우 SQL Server는 메모리를 버퍼 풀에 할당합니다. SQL Server는 작업에 메모리가 많이 필요한 경우에만 메모리를 버퍼 풀에 추가합니다. 유휴 상태의 서버는 버퍼 풀의 크기를 증가시키지 않습니다.
Windows Server 2003에서 SQL Server는 메모리 알림 API QueryMemoryResourceNotification을 사용하여 버퍼 풀이 메모리를 할당하고 해제하는 시기를 결정합니다.
SQL Server에서 메모리를 동적으로 사용할 수 있게 하는 것이 좋지만 메모리 옵션을 수동으로 설정하고 SQL Server에서 액세스할 수 있는 메모리 양을 제한할 수 있습니다. SQL Server 메모리 양을 설정하기 전에 Windows 2000 또는 Windows Server 2003 및 기타 다른 SQL Server 인스턴스(및 다른 시스템 - 컴퓨터가 SQL Server 전용이 아닌 경우)에 필요한 메모리를 총 실제 메모리에서 빼서 적합한 메모리 설정을 결정합니다. 이러한 차이 값이 SQL Server에 할당할 수 있는 최대 메모리 양입니다.
메모리 옵션 수동 설정
SQL Server 메모리 옵션을 수동으로 설정하는 데는 두 가지 주요 방법이 있습니다.
- 첫째 방법은 min server memory 및 max server memory를 같은 값으로 설정하는 것입니다. 이 값은 해당 값에 도달한 후에 SQL Server 버퍼 풀에 할당되는 고정 메모리 양에 해당합니다.
- 둘째 방법에서는 min server memory 및 max server memory를 설정하여 메모리 값 범위를 확장합니다. 이 방법은 시스템 또는 데이터베이스 관리자가 같은 컴퓨터에서 실행 중인 다른 응용 프로그램의 메모리 요구 사항과 관련하여 SQL Server 인스턴스를 구성하는 경우 유용합니다.
min server memory를 사용하여 SQL Server 인스턴스의 버퍼 풀에 사용 가능한 최소 메모리 양을 보장할 수 있습니다. SQL Server는 시작할 때 min server memory에 지정된 메모리 양을 즉시 할당하지 않습니다. 그러나 클라이언트 로드 때문에 메모리 사용량이 이 값에 도달하면 min server memory 값을 줄이기 전에는 SQL Server가 할당된 버퍼 풀에서 메모리를 비울 수 없습니다.
[!참고] SQL Server에서는 min server memory에 지정된 메모리 양을 할당하는 것은 보장하지 않습니다. 서버의 로드 때문에 min server memory에 지정된 메모리 양을 할당할 필요가 없는 경우 SQL Server는 보다 적은 메모리로 실행됩니다.
max server memory를 사용하면 SQL Server 버퍼 풀이 지정된 양 이상의 메모리를 사용하지 못하게 되므로 나머지 메모리를 다른 응용 프로그램을 빨리 시작하는 데 사용할 수 있습니다. SQL Server는 시작할 때 max server memory에서 지정된 메모리를 즉시 할당하지 않습니다. 메모리 사용량은 max server memory에 지정된 값에 도달할 때까지 SQL Server에서 필요한 만큼 증가됩니다. SQL Server는 max server memory 값을 늘리기 전에는 이 메모리 사용량을 초과할 수 없습니다.
max server memory 값을 줄이기 전에 성능 모니터를 사용하여 부하 상태에서 SQLServer:Buffer Manager 성능 개체를 검사하고 Stolen pages 및 Reserved pages 카운터의 현재 값을 확인합니다. 이러한 카운터는 8K 페이지 수로 메모리를 보고합니다. 메모리 부족 오류를 방지하려면 max server memory를 두 값의 합계보다 크도록 설정해야 합니다. 가장 낮은 적절한 max server memory 설정 값(MB)은 대략 ([Stolen pages] + [Reserved pages])/ 100입니다. max server memory를 줄이려면 SQL Server를 다시 시작하여 메모리를 해제해야 할 수도 있습니다.
네트워크 응용 프로그램을 위해 데이터 처리량 최대화
네트워크 응용 프로그램을 위해 데이터 처리량 최대화 네트워크 연결 옵션이 선택되면 운영 체제는 해당 I/O 페이지를 파일 시스템 캐시에 저장하여 버퍼링된 I/O 작업을 수행하는 응용 프로그램을 우선적으로 처리합니다. 이 옵션은 정상적인 작업을 수행하는 동안 SQL Server에서 사용 가능한 메모리를 제한할 수 있습니다.
운영 체제의 현재 설정을 확인하려면
시작, 제어판을 차례로 클릭한 다음 네트워크 연결 및 로컬 영역 연결을 차례로 두 번 클릭합니다.
일반 탭에서 속성을 클릭하고 Microsoft 네트워크용 파일 및 프린터 공유를 선택한 다음 속성을 클릭합니다.
네트워크 응용 프로그램을 위해 데이터 처리량 최대화가 선택된 경우에는 다른 옵션을 선택하고 확인을 클릭한 다음 나머지 대화 상자를 닫습니다.
Windows Server 2003의 AWE 메모리
Windows Server 2003에서 SQL Server 2005는 운영 체제의 메모리 요구 사항과 자체 메모리 요구 사항 간의 로드 균형을 조정하는 데 유용한 AWE(Address Windowing Extensions) 메모리를 사용할 수 있습니다. SQL Server 및 운영 체제 간의 균형 조정 시 min server memory 및 max server memory 옵션의 제약 조건에 따라 다릅니다. 서버 하드웨어에서 Hot-Add 메모리를 지원하는 경우 시스템을 다시 시작할 필요 없이 필요한 만큼 실제 메모리를 서버에 추가할 수 있습니다. awe enabled 구성 옵션에 대한 자세한 내용은 awe enabled 옵션을 참조하십시오. 자세한 내용은 Hot Add 메모리를 참조하십시오.
[!참고] Windows Server 2003에서 동적 AWE 메모리는 구성된 가상 메모리 제한값보다 적은 실제 메모리로 서버에서 지원됩니다. Windows 2000에서 AWE 메모리를 사용하려면 사용 가능한 실제 메모리가 가상 메모리를 초과해야 합니다.
시스템에서 페이지가 디스크로 스왑되지 않게 하고 SQL Server에 가능한 한 많은 양의 메모리를 할당하는 것이 이상적입니다. 임계값은 시스템에 따라 달라집니다. 예를 들어 SQL Server 전용 32GB 시스템에서는 30-31GB가 SQL Server에 적절한 최대 임계값이고 64GB 시스템에서는 60-62GB가 적절한 임계값이 될 수 있습니다.
[!참고] SQL Server 메모리 양을 늘리면 추가 메모리를 수용하기 위해 운영 체제의 가상 메모리 지원 파일(Pagefile.sys)을 확장할 수 있을만큼 디스크 공간이 충분한지 확인해야 합니다. 가상 메모리 지원 파일에 대한 자세한 내용은 Windows 2000 및 Windows Server 2003 설명서를 참조하십시오.
Windows 시스템 모니터의 통계를 사용하여 필요한 경우 메모리 값을 조정할 수 있습니다. 이 값은 메모리를 추가 또는 제거하거나 시스템 사용 방법을 변경할 때만 변경하십시오.
가상 메모리 관리자
Windows 2000 및 Windows Server 2003 같은 32비트 운영 체제는 4GB의 가상 주소 공간에 대한 액세스를 제공합니다. 하위 2GB의 가상 메모리는 프로세스 전용이며 응용 프로그램에서만 사용 가능합니다. 상위 2GB는 운영 체제에서 사용할 수 있도록 예약되어 있습니다. Windows Server 2003을 포함하여 Microsoft Windows XP Professional 이후 버전으로 시작되는 모든 운영 체제 버전에는 운영 체제를 1GB로 제한하면서 3GB의 가상 메모리에 대한 액세스를 응용 프로그램에 제공할 수 있는 boot.ini 스위치가 있습니다. /3GB 스위치 메모리 구성을 사용하는 방법은 해당 Windows 설명서를 참조하십시오.
[!참고] Windows Server 2003에서 PAE는 서버가 Hot Add 메모리 장치를 사용하는 경우에만 자동으로 설정됩니다. 이 경우 Hot Add 메모리 장치를 사용하도록 구성된 시스템에서 /PAE 스위치를 사용하지 않아도 됩니다. 다른 모든 경우에서 4GB가 넘는 메모리를 이용하려면 Boot.ini 파일의 /PAE 스위치를 사용해야 합니다.
4GB 주소 공간은 Windows 가상 메모리 관리자(VMM)에 의해 사용할 수 있는 실제 메모리에 매핑됩니다. Windows Server 2003 운영 체제가 도입되면서 지원되는 실제 메모리 양이 증가되었습니다. 따라서 AWE에서 액세스 가능한 실제 메모리는 사용하는 응용 프로그램에 따라 다릅니다.
- Windows Server 2003 Standard Edition에서는 실제 메모리를 4GB까지 지원합니다.
- Windows Server 2003 Enterprise Edition에서는 실제 메모리를 32GB까지 지원합니다.
- Windows Server 2003 Datacenter Edition에서는 실제 메모리를 64GB까지 지원합니다.
SQL Server 등의 Win32 응용 프로그램은 실제 주소가 아니라 가상 주소나 논리적 주소만 인식합니다. 응용 프로그램이 특정 시간(현재 설정)동안 사용한 실제 메모리의 양은 사용할 수 있는 실제 메모리와 VMM에 의해 결정됩니다. 응용 프로그램은 메모리 사용량을 직접 제어할 수 없습니다.
Windows Server 2003 Enterprise Server 및 Windows Server 2003 Datacenter Server 32비트 버전뿐만 아니라 Windows 2000 Advanced Server 및 Windows 2000 Datacenter Server 버전의 경우 Intel PAE(Physical Addressing Extensions)를 사용하므로 4GB의 제한을 초과할 수 있습니다. Windows boot.ini 구성 파일의 /PAE 스위치를 사용하면 4GB의 제한을 초과하는 실제 메모리에 액세스할 수 있습니다. 이것은 4GB 이상의 AWE 메모리 액세스에 대한 요구 사항입니다. Windows 2000 및 Windows Server 2003에 대한 메모리 구성 사용 방법은 Windows 설명서를 참조하십시오.
Windows 2000 또는 Windows Server 2003 등의 가상 주소 체계를 사용하면 실제 메모리가 과다 커밋되어 가상 메모리와 실제 메모리의 비율이 1:1을 초과할 수 있습니다. 그 결과 실제 메모리가 다양하게 구성된 컴퓨터에서 대용량 프로그램을 실행할 수 있습니다. 그러나 모든 프로세스의 현재 평균 설정을 합한 값보다 너무 많은 가상 메모리를 사용하면 성능이 떨어집니다.
min server memory 및 max server memory는 고급 옵션입니다. sp_configure 시스템 저장 프로시저를 사용하여 설정을 변경하면 show advanced options를 1로 설정할 때만 이 옵션을 바꿀 수 있습니다. 이 설정은 서버를 다시 시작할 필요 없이 바로 적용됩니다.
여러 SQL Server 인스턴스 실행
여러 데이터베이스 엔진 인스턴스를 실행하는 경우 다음 3가지 방법으로 메모리를 관리할 수 있습니다.
- max server memory를 사용하여 메모리 사용을 제어합니다. 허용되는 총 메모리가 컴퓨터의 실제 메모리 합계보다 크지 않도록 주의하여 각 인스턴스의 최대값을 설정합니다. 예상 작업이나 데이터베이스 크기에 비례하여 각 인스턴스에 메모리를 제공할 수 있습니다. 이 방법은 새 프로세스나 인스턴스 시작 시 여유 메모리를 즉시 사용할 수 있다는 장점이 있습니다. 단점은 모든 인스턴스를 실행하지 않는 경우 실행 중인 인스턴스가 남은 여유 메모리를 사용할 수 없다는 것입니다.
- min server memory를 사용하여 메모리 사용을 제어합니다. 최소값의 합계가 컴퓨터의 실제 메모리 합계보다 1-2GB 작도록 각 인스턴스의 최소값을 설정합니다. 또한 해당 인스턴스의 예상 부하에 비례하여 이러한 최소값을 설정할 수 있습니다. 이 방법은 모든 인스턴스를 동시에 실행하지 않는 경우 실행 중인 인스턴스에서 남은 여유 메모리를 사용할 수 있다는 장점이 있습니다. 또한 이 방법은 SQL Server에 적절한 양의 메모리가 최소한 할당되도록 하기 때문에 컴퓨터에 메모리를 많이 사용하는 다른 프로세스가 있을 때 유용합니다. 단점은 새 인스턴스나 다른 프로세스 시작 시, 특히 메모리를 해제하기 위해 수정된 페이지를 다시 데이터베이스에 써야 하는 경우 실행 중인 인스턴스가 메모리를 해제하는 데 오랜 시간이 걸린다는 것입니다. 페이징 파일의 크기를 훨씬 늘려야 할 수도 있습니다.
- 아무 작업도 하지 않습니다(권장되지 않음). 작업이 제공되는 첫 번째 인스턴스에서 모든 메모리를 할당합니다. 유휴 인스턴스나 나중에 시작된 인스턴스는 사용 가능한 최소 메모리만으로 실행될 수도 있습니다. SQL Server 2005에서는 인스턴스의 메모리 사용을 조절하지 않습니다. 그러나 모든 인스턴스는 Windows 메모리 알림 신호에 응답하여 버퍼 풀의 크기를 조절합니다. Windows 2003 Server SP1을 기준으로 Windows는 메모리 알림 API가 있는 응용 프로그램에서 메모리 균형을 유지하지 않고 단순히 시스템의 메모리 사용 가능 여부에 대한 전역 피드백만 제공합니다.
인스턴스를 다시 시작하지 않고 이러한 설정을 변경할 수 있으므로 사용 패턴에 가장 맞는 설정을 쉽게 찾을 수 있습니다.
참고 항목
개념
성능 모니터링 및 튜닝
서버 구성 옵션 설정
SQL Server에 대한 AWE 메모리 활성화
관련 자료
RECONFIGURE(Transact-SQL)
복제 설명서 구조
sp_configure(Transact-SQL)
도움말 및 정보
변경 내역
릴리스 | 내역 |
---|---|
2006년 4월 14일 |
|
2005년 12월 5일 |
|