CPU 사용 모니터링
Microsoft SQL Server 의 인스턴스를 정기적으로 모니터링하여 CPU 사용량이 정상 범위에 있는지 확인할 수 있습니다. CPU 사용량이 계속 높게 나타나면 CPU 업그레이드 또는 멀티 프로세서 추가가 필요하거나 응용 프로그램 튜닝 또는 디자인이 적절하지 않다는 의미일 수 있습니다. 응용 프로그램을 최적화하면 CPU 사용률을 낮출 수 있습니다.
CPU 사용량을 확인하는 효과적인 방법은 시스템 모니터의 Processor:% Processor Time 카운터를 사용하는 것입니다. 카운터는 CPU가 비유휴 스레드를 실행하는 데 소비하는 시간을 모니터링합니다. 카운터 값이 계속 80-90%로 나타나면 CPU를 업그레이드하거나 프로세서를 추가해야 할 수 있습니다. 다중 프로세서 시스템에서는 각 프로세서에 대해 이 카운터의 개별 인스턴스를 모니터링해야 합니다. 이 값은 특정 프로세서의 프로세서 시간의 합을 나타냅니다. 모든 프로세서의 평균을 확인하려면 System: %Total Processor Time 카운터를 대신 사용합니다.
다음과 같은 카운터를 모니터링하여 프로세스 사용을 모니터링할 수도 있습니다.
Processor: % Privileged Time
프로세서가 SQL Server I/O 요청 처리와 같은 Microsoft Windows 커널 명령을 실행하는 데 소비하는 시간의 백분율에 해당합니다. Physical Disk 카운터가 높을 때 이 카운터가 같이 높으면 더 빠르고 효율적인 디스크 하위 시스템을 설치하십시오.[!참고] 디스크 컨트롤러와 드라이버가 다르면 커널 처리 시간도 다릅니다. 효율적인 컨트롤러와 드라이버를 사용하면 권한 시간이 짧아져 사용자가 응용 프로그램을 사용할 수 있는 처리 시간을 확보할 수 있기 때문에 전체 처리량을 늘릴 수 있습니다.
Processor: %User Time
프로세서가 SQL Server 와 같은 사용자 프로세스를 실행하는 데 소비하는 시간의 백분율에 해당합니다.System: Processor Queue Length
프로세서 시간을 기다리는 스레드 수에 해당합니다. 프로세스의 스레드에 필요한 프로세서 사이클 수가 사용할 수 있는 개수보다 많으면 프로세서 병목 상태가 발생합니다. 여러 프로세스에서 프로세서 시간을 이용하려고 하면 더 빠른 프로세서를 설치해야 합니다. 또는 다중 프로세서 시스템에서는 프로세서를 추가할 수 있습니다.
프로세서 사용량을 조사할 때는 SQL Server 인스턴스에서 수행하는 작업 유형을 고려하십시오. SQL Server 가 집계 관련 쿼리나 디스크 I/O가 필요 없는 메모리 집중형 쿼리와 같은 계산을 많이 수행한다면 프로세서 시간 전체를 사용할 수 있습니다. 그 결과 다른 응용 프로그램의 성능이 저하되면 작업을 변경해 보십시오. 예를 들어 컴퓨터가 SQL Server 인스턴스 실행을 전담하도록 합니다.
많은 클라이언트 요청이 처리되는 경우 사용률이 100%에 가까우면 프로세스가 큐에 대기하고 프로세서 시간을 기다리고 있으며 병목 상태가 발생할 수 있음을 나타냅니다. 빠른 프로세서를 추가하여 문제를 해결할 수 있습니다.