SQL Server 리소스 제어

완료됨

일부 SQL Server 또는 Azure SQL 관리형 인스턴스는 단일 애플리케이션의 데이터베이스 전용이지만, 중요 업무용 애플리케이션에서 자주 볼 수 있는 구성이지만, 많은 서버는 다양한 성능 요구 사항과 최대 워크로드 주기를 가진 여러 애플리케이션에 대한 데이터베이스를 지원합니다. 이러한 서로 다른 요구 사항의 균형을 맞추는 것은 관리자에게 어려울 수 있습니다. 서버 리소스를 관리하는 한 가지 효과적인 방법은 SQL Server 2008에 도입된 Resource Governor를 사용하는 것입니다.

Resource Governor 는 들어오는 애플리케이션 요청에 대한 CPU, 물리적 I/O 및 메모리 리소스를 세부적으로 제어할 수 있는 SQL Server 및 Azure SQL 관리형 인스턴스의 기능입니다. 인스턴스 수준에서 사용하도록 설정된 경우 Resource Governor는 분류자 함수를 사용하여 연결을 처리하는 방법을 정의하고 세션을 워크로드 그룹으로 세분화합니다. 각 워크로드 그룹은 특정 시스템 리소스 풀을 사용하도록 구성됩니다.

리소스 풀

리소스 풀은 서버에서 사용할 수 있는 실제 리소스를 나타냅니다. SQL Server에는 항상 Resource Governor를 사용하도록 설정하지 않은 경우에도 기본 풀과 내부 풀이 두 개 있습니다. 내부 풀은 중요한 SQL Server 함수용으로 예약되어 있으며 제한할 수 없습니다. 명시적으로 정의한 리소스 풀과 함께 기본 풀은 사용할 수 있는 리소스에 대한 제한으로 구성할 수 있습니다. 각 비인터널 풀에 대해 다음 제한을 지정할 수 있습니다.

  • 최소/최대 CPU 비율
  • CPU 비율 한도
  • 최소/최대 메모리 비율
  • NUMA 노드 선호도
  • 볼륨당 최소/최대 IOP

참고

리소스 풀에 대한 변경 내용은 이미 진행 중인 세션이 아닌 새 세션에만 영향을 줍니다. 따라서 풀을 수정해도 장기 실행 프로세스의 리소스가 제한되지는 않습니다. 이 규칙의 예외는 SQL Server Machine Learning Services와 함께 사용되는 외부 풀이며, 진행 중인 세션의 경우에도 풀 변경으로 제한될 수 있습니다.

최소 및 최대 CPU 비율을 제외한 모든 리소스 풀 설정은 초과할 수 없는 하드 제한을 나타냅니다. 최소/최대 CPU 백분율은 CPU 경합이 있는 경우에만 적용됩니다. 예를 들어 최대 70개의%설정하는 경우 경합이 없을 때 워크로드에서 최대 100% 사용 가능한 CPU 주기를 사용할 수 있습니다. 그러나 다른 워크로드가 실행되는 경우 워크로드는%70으로 제한됩니다.

워크로드 그룹

워크로드 그룹은 분류자 함수로 분류된 세션 요청의 컨테이너 역할을 합니다. 리소스 풀과 마찬가지로 기본 그룹과 내부 그룹이라는 두 개의 기본 제공 그룹이 있습니다. 각 워크로드 그룹은 단일 리소스 풀과 연결되지만 리소스 풀은 여러 워크로드 그룹을 호스트할 수 있습니다. 기본적으로 분류자 함수가 사용자 정의 그룹에 할당하지 않는 한 모든 연결은 기본 워크로드 그룹으로 전달됩니다. 기본 워크로드 그룹은 기본 리소스 풀에 할당된 리소스를 활용합니다.

분류자 함수

분류자 함수는 SQL Server 인스턴스에 대한 연결이 설정될 때 실행되며 각 연결을 지정된 워크로드 그룹으로 분류합니다. 함수가 NULL, 기본값 또는 존재하지 않는 워크로드 그룹의 이름을 반환하는 경우 세션이 기본 워크로드 그룹으로 전송됩니다. 분류자는 모든 연결에서 실행되므로 효율성을 테스트해야 합니다. 다음 이미지에서는 사용자 이름에 따라 사용자를 분류하는 샘플 분류자 함수를 보여줍니다.

CREATE FUNCTION dbo.RGClassifier()
RETURNS SYSNAME
WITH SCHEMABINDING
AS
BEGIN
DECLARE @WorkloadGroup AS SYSNAME
IF(SUSER_NAME() = 'ReportUser')
    SET @WorkloadGroup = 'ReportServerGroup'

ELSE IF (SUSER_NAME() = 'PrimaryUser')
    SET @WorkloadGroup = 'PrimaryServerGroup'
ELSE
    SET @WorkloadGroup = 'default'

RETURN @WorkloadGroup
END

예제에 표시된 함수 정의의 복잡성을 늘릴 수 있지만 더 복잡한 함수가 사용자 성능에 영향을 주지 않는지 확인해야 합니다.

Resource Governor 사용 사례

Resource Governor는 데이터베이스 그룹이 단일 SQL Server 인스턴스를 공유하고 서버의 모든 사용자에 대해 성능을 일관되게 유지해야 하는 다중 테넌트 시나리오에서 주로 사용됩니다. 또한 Resource Governor를 사용하여 일관성 확인 및 인덱스 다시 작성 등의 유지 관리 작업에 사용되는 리소스를 제한하여 유지 관리 기간 동안 사용자 쿼리에 충분한 리소스를 보장할 수 있습니다.