CREATE WORKLOAD GROUP(Transact-SQL)
제품 선택
다음 행에서 관심 있는 제품 이름을 선택하면 해당 제품의 정보만 표시됩니다.
* SQL Server *
SQL Server 및 SQL Managed Instance
리소스 관리자 워크로드 그룹을 만들고 워크로드 그룹을 리소스 관리자 리소스 풀에 연결합니다.
리소스 관리자는 SQL Server의 모든 버전에서 사용할 수 없습니다. SQL Server 버전에서 지원되는 기능 목록은 SQL Server 2022의 버전과 지원하는 기능을 참조하세요.
참고
Azure SQL Managed Instance의 경우 리소스 관리자 구성을 수정하려면 master
데이터베이스의 컨텍스트에 있어야 합니다.
구문
CREATE WORKLOAD GROUP group_name
[ WITH
( [ IMPORTANCE = { LOW | MEDIUM | HIGH } ]
[ [ , ] REQUEST_MAX_MEMORY_GRANT_PERCENT = value ]
[ [ , ] REQUEST_MAX_CPU_TIME_SEC = value ]
[ [ , ] REQUEST_MEMORY_GRANT_TIMEOUT_SEC = value ]
[ [ , ] MAX_DOP = value ]
[ [ , ] GROUP_MAX_REQUESTS = value ] )
]
[ USING {
[ pool_name | [default] ]
[ [ , ] EXTERNAL external_pool_name | [default] ]
} ]
[ ; ]
인수
group_name
작업 그룹에 대한 사용자 정의 이름입니다.
IMPORTANCE = { LOW | MEDIUM | HIGH }
작업 그룹에 있는 요청의 상대적 중요도를 지정합니다. 기본값은 MEDIUM
.
IMPORTANCE
워크로드 그룹을 포함하는 리소스 풀에 로컬입니다. 동일한 리소스 풀 내에서 중요도가 다른 워크로드 그룹은 서로 영향을 주지만 다른 리소스 풀의 워크로드 그룹에는 영향을 주지 않습니다.
REQUEST_MAX_MEMORY_GRANT_PERCENT = value
단일 요청이 풀에서 가져올 수 있는 최대 쿼리 작업 영역 메모리 양을 지정합니다.
SQL Server 2017(14.x) 이상에서는
SQL Server 2019(15.x)부터 값은 float
데이터 형식을 사용하여 소수 자릿수일 수 있습니다. 허용되는 범위는 0에서 100까지입니다.
중요
지정된 양은 쿼리 메모리 부여를 통해 얻은 쿼리 작업 영역 메모리만을 나타냅니다.
서버가 다른 동시 쿼리에 대해 충분한 여유 메모리를 따로 설정할 수 없으므로 값을 너무 크게 설정하지 않는 것이 좋습니다(예: 70보다 큼). 이로 인해 메모리 부여 시간이 초과 오류 8645발생할 수 있습니다.
값을 0 또는 작은 값으로 설정하면 sort
및 hash
같은 작업 영역 메모리가 필요한 연산자가 있는 쿼리가 사용자 정의 워크로드 그룹에서 실행되지 않을 수 있습니다. 쿼리 메모리 요구 사항이 이 매개 변수에 정의된 제한을 초과하면 다음 동작이 발생합니다.
- 사용자 정의 워크로드 그룹의 경우 서버는 메모리 요구 사항이 한도에 해당하거나 DOP가 1이 될 때까지 요청(쿼리)의 DOP(병렬 처리 수준)를 줄이려고 합니다. 쿼리 메모리 요구 사항이 여전히 한도보다 크면 오류 8657이 발생하고 쿼리가 실패합니다.
-
internal
및default
워크로드 그룹의 경우 서버는 쿼리가 필요한 메모리를 가져오도록 허용합니다.
두 경우 모두 서버에 실제 메모리가 부족한 경우 오류 8645 발생할 수 있습니다.
REQUEST_MAX_CPU_TIME_SEC = value
일괄 처리 요청에서 사용할 수 있는 최대 CPU 시간(초)을 지정합니다. value는 0 또는 양의 정수여야 합니다. value의 기본 설정인 0은 무제한을 의미합니다.
최대 CPU 시간을 초과하면 cpu_threshold_exceeded
확장 이벤트 및 추적 이벤트가 생성됩니다. 자세한 내용은 CPU Threshold Exceeded 이벤트 클래스를 참조하세요.
Azure SQL Managed Instance에서 최대 CPU 시간이 초과되면 리소스 관리자가 오류 10961로 요청을 중단합니다.
SQL Server에서 리소스 관리자는 기본적으로 요청을 중단하지 않습니다. 그러나 SQL Server 2016(13.x) SP2 및 SQL Server 2017(14.x) CU3부터 리소스 관리자는 추적 플래그 2422 사용하도록 설정되고 최대 CPU 시간이 초과되면 오류 10961로 요청을 중단합니다.
참고
CPU 시간 사용량에 대한 검색 간격은 5초입니다. 쿼리가 지정된 제한을 5초 이상 초과하면 이벤트가 생성됩니다. 그러나 쿼리가 지정된 임계값을 5초 미만으로 초과하는 경우 쿼리의 타이밍 및 마지막 검색 스윕 시간에 따라 검색이 누락될 수 있습니다.
REQUEST_MEMORY_GRANT_TIMEOUT_SEC = value
쿼리 작업 영역 메모리의 메모리 부여가 사용 가능해질 때까지 쿼리에서 대기할 수 있는 최대 시간(초)을 지정합니다. value는 0 또는 양의 정수여야 합니다. value의 기본 설정인 0은 쿼리 비용에 따른 내부 계산을 사용하여 최대 시간을 결정합니다.
메모리 부여 제한 시간에 도달하면 쿼리가 항상 실패하지는 않습니다. 쿼리가 너무 많은 동시 쿼리가 실행 중인 경우에만 실패합니다. 그렇지 않으면 쿼리가 최소 메모리 부여만 가져와 쿼리 성능이 저하될 수 있습니다.
MAX_DOP = value
병렬 쿼리 실행에 대한 최대 병렬 처리 수준(MAXDOP
)을 지정합니다. 허용되는 value의 범위는 0에서 64까지입니다.
value의 기본 설정 0은 전역 설정을 사용합니다.
자세한 내용은 MAXDOP참조하세요.
GROUP_MAX_REQUESTS = value
작업 그룹에서 실행할 수 있는 최대 동시 요청 수를 지정합니다. value는 0 또는 양의 정수여야 합니다. 값의 기본 설정은 0이며, 무제한 요청을 허용합니다. 최대 동시 요청에 도달하면 해당 그룹의 세션을 만들 수 있지만 동시 요청 수가 지정된 값 아래로 떨어질 때까지 대기 상태에 배치됩니다.
USING { pool_name | [기본값] }
워크로드 그룹을 pool_name식별된 사용자 정의 리소스 풀 또는 default
리소스 풀과 연결합니다.
pool_name 제공되지 않거나 USING
인수가 지정되지 않은 경우 워크로드 그룹은 기본 제공 default
풀과 연결됩니다.
default
예약어이며 USING
지정된 경우 대괄호([]
) 또는 따옴표(""
)로 묶어야 합니다.
기본 제공 리소스 풀 및 워크로드 그룹은 default
같은 모든 소문자 이름을 사용합니다. 대/소문자 구분 데이터 정렬을 사용하는 서버에서 소문자 default
사용합니다. 대/소문자를 구분하지 않는 데이터 정렬이 있는 서버는 default
, Default
및 DEFAULT
동일한 값으로 처리합니다.
EXTERNAL external_pool_name | [기본값]
적용 대상: SQL Server 2016(13.x) 이상
작업 그룹은 외부 리소스 풀을 지정할 수 있습니다. 워크로드 그룹을 정의하고 다음 두 풀과 연결할 수 있습니다.
- 데이터베이스 엔진 워크로드에 대한 리소스 풀입니다.
- 외부 프로세스에 대한 외부 리소스 풀. 자세한 내용은 sp_execute_external_script참조하세요.
설명
자세한 내용은 Resource Governor 및 Resource Governor 워크로드 그룹참조하세요.
MAXDOP
지정된 쿼리의 경우 유효한 MAXDOP
다음과 같이 결정됩니다.
- 쿼리 힌트로
MAXDOP
작업 그룹MAX_DOP
설정을 초과하지 않는 한 적용됩니다. - 쿼리 힌트로
MAXDOP
항상max degree of parallelism
서버 구성을 재정의합니다. 자세한 내용은 Server 구성을 참조하세요. 최대 병렬 처리 수준. - 워크로드 그룹
MAX_DOP
max degree of parallelism
서버 구성 및MAXDOP
데이터베이스 범위 구성재정의합니다.
MAXDOP
제한은 작업별로 설정됩니다.
요청별 또는 쿼리 제한별로 수행되지 않습니다. 병렬 쿼리를 실행하는 동안 단일 요청은 스케줄러할당된 여러 작업을 생성할 수 있습니다. 자세한 내용은 스레드 및 작업 아키텍처 가이드참조하세요.
쿼리가 컴파일 시간(MAXDOP = 1
)에 직렬로 표시되면 워크로드 그룹 또는 서버 구성 설정에 관계없이 런타임에 병렬 처리로 실행할 수 없습니다. 쿼리에 대해 MAXDOP
결정된 후에는 메모리 압력으로 인해 낮출 수 있습니다. 워크로드 그룹 재구성은 메모리 부여 큐에서 대기 중인 쿼리에 영향을 주지 않습니다.
인덱스 만들기
성능상의 이유로 인덱스 만들기는 처음에 부여된 것보다 더 많은 메모리 작업 영역을 사용할 수 있습니다. 리소스 관리자는 이 특별 처리를 지원합니다. 그러나 초기 권한 부여 및 추가 메모리 부여는 워크로드 그룹 및 리소스 풀 설정에 의해 제한됩니다.
분할된 테이블에서 정렬되지 않은 인덱스를 만드는 데 사용되는 메모리는 관련된 파티션 수에 비례합니다. 필요한 총 메모리가 REQUEST_MAX_MEMORY_GRANT_PERCENT
워크로드 그룹 설정에 의해 적용되는 쿼리당 제한을 초과하면 인덱스 생성이 실패할 수 있습니다.
default
워크로드 그룹을 사용하면 쿼리가 이전 버전과의 호환성을 위해 시작하는 데 필요한 최소 메모리로 쿼리당 제한을 초과할 수 있으므로 default
리소스 풀에 충분한 총 메모리가 있는 경우 default
워크로드 그룹을 사용하여 동일한 인덱스를 만들 수 있습니다.
사용 권한
CONTROL SERVER
권한이 필요합니다.
예제
newReports
리소스 풀에 default
이라는 워크로드 그룹을 만들고 최대 메모리 부여, 요청에 대한 최대 CPU 시간 및 MAXDOP
제한합니다.
CREATE WORKLOAD GROUP newReports
WITH (
REQUEST_MAX_MEMORY_GRANT_PERCENT = 2.5,
REQUEST_MAX_CPU_TIME_SEC = 100,
MAX_DOP = 4
)
USING [default];
관련 콘텐츠
- 자습서: 리소스 관리자 구성 예제 및 모범 사례
- 리소스 관리자
- Resource Governor 워크로드 그룹
- 워크로드 그룹 만들기
- ALTER WORKLOAD GROUP
- 워크로드 그룹 삭제
- 리소스 풀 만들기
- ALTER RESOURCE POOL
- 리소스 풀 삭제
- ALTER RESOURCE GOVERNOR
* SQL Managed Instance *
SQL Server 및 SQL Managed Instance
리소스 관리자 워크로드 그룹을 만들고 워크로드 그룹을 리소스 관리자 리소스 풀에 연결합니다.
리소스 관리자는 SQL Server의 모든 버전에서 사용할 수 없습니다. SQL Server 버전에서 지원되는 기능 목록은 SQL Server 2022의 버전과 지원하는 기능을 참조하세요.
참고
Azure SQL Managed Instance의 경우 리소스 관리자 구성을 수정하려면 master
데이터베이스의 컨텍스트에 있어야 합니다.
구문
CREATE WORKLOAD GROUP group_name
[ WITH
( [ IMPORTANCE = { LOW | MEDIUM | HIGH } ]
[ [ , ] REQUEST_MAX_MEMORY_GRANT_PERCENT = value ]
[ [ , ] REQUEST_MAX_CPU_TIME_SEC = value ]
[ [ , ] REQUEST_MEMORY_GRANT_TIMEOUT_SEC = value ]
[ [ , ] MAX_DOP = value ]
[ [ , ] GROUP_MAX_REQUESTS = value ] )
]
[ USING {
[ pool_name | [default] ]
[ [ , ] EXTERNAL external_pool_name | [default] ]
} ]
[ ; ]
인수
group_name
작업 그룹에 대한 사용자 정의 이름입니다.
IMPORTANCE = { LOW | MEDIUM | HIGH }
작업 그룹에 있는 요청의 상대적 중요도를 지정합니다. 기본값은 MEDIUM
.
IMPORTANCE
워크로드 그룹을 포함하는 리소스 풀에 로컬입니다. 동일한 리소스 풀 내에서 중요도가 다른 워크로드 그룹은 서로 영향을 주지만 다른 리소스 풀의 워크로드 그룹에는 영향을 주지 않습니다.
REQUEST_MAX_MEMORY_GRANT_PERCENT = value
단일 요청이 풀에서 가져올 수 있는 최대 쿼리 작업 영역 메모리 양을 지정합니다.
SQL Server 2017(14.x) 이상에서는
SQL Server 2019(15.x)부터 값은 float
데이터 형식을 사용하여 소수 자릿수일 수 있습니다. 허용되는 범위는 0에서 100까지입니다.
중요
지정된 양은 쿼리 메모리 부여를 통해 얻은 쿼리 작업 영역 메모리만을 나타냅니다.
서버가 다른 동시 쿼리에 대해 충분한 여유 메모리를 따로 설정할 수 없으므로 값을 너무 크게 설정하지 않는 것이 좋습니다(예: 70보다 큼). 이로 인해 메모리 부여 시간이 초과 오류 8645발생할 수 있습니다.
값을 0 또는 작은 값으로 설정하면 sort
및 hash
같은 작업 영역 메모리가 필요한 연산자가 있는 쿼리가 사용자 정의 워크로드 그룹에서 실행되지 않을 수 있습니다. 쿼리 메모리 요구 사항이 이 매개 변수에 정의된 제한을 초과하면 다음 동작이 발생합니다.
- 사용자 정의 워크로드 그룹의 경우 서버는 메모리 요구 사항이 한도에 해당하거나 DOP가 1이 될 때까지 요청(쿼리)의 DOP(병렬 처리 수준)를 줄이려고 합니다. 쿼리 메모리 요구 사항이 여전히 한도보다 크면 오류 8657이 발생하고 쿼리가 실패합니다.
-
internal
및default
워크로드 그룹의 경우 서버는 쿼리가 필요한 메모리를 가져오도록 허용합니다.
두 경우 모두 서버에 실제 메모리가 부족한 경우 오류 8645 발생할 수 있습니다.
REQUEST_MAX_CPU_TIME_SEC = value
일괄 처리 요청에서 사용할 수 있는 최대 CPU 시간(초)을 지정합니다. value는 0 또는 양의 정수여야 합니다. value의 기본 설정인 0은 무제한을 의미합니다.
최대 CPU 시간을 초과하면 cpu_threshold_exceeded
확장 이벤트 및 추적 이벤트가 생성됩니다. 자세한 내용은 CPU Threshold Exceeded 이벤트 클래스를 참조하세요.
Azure SQL Managed Instance에서 최대 CPU 시간이 초과되면 리소스 관리자가 오류 10961로 요청을 중단합니다.
SQL Server에서 리소스 관리자는 기본적으로 요청을 중단하지 않습니다. 그러나 SQL Server 2016(13.x) SP2 및 SQL Server 2017(14.x) CU3부터 리소스 관리자는 추적 플래그 2422 사용하도록 설정되고 최대 CPU 시간이 초과되면 오류 10961로 요청을 중단합니다.
참고
CPU 시간 사용량에 대한 검색 간격은 5초입니다. 쿼리가 지정된 제한을 5초 이상 초과하면 이벤트가 생성됩니다. 그러나 쿼리가 지정된 임계값을 5초 미만으로 초과하는 경우 쿼리의 타이밍 및 마지막 검색 스윕 시간에 따라 검색이 누락될 수 있습니다.
REQUEST_MEMORY_GRANT_TIMEOUT_SEC = value
쿼리 작업 영역 메모리의 메모리 부여가 사용 가능해질 때까지 쿼리에서 대기할 수 있는 최대 시간(초)을 지정합니다. value는 0 또는 양의 정수여야 합니다. value의 기본 설정인 0은 쿼리 비용에 따른 내부 계산을 사용하여 최대 시간을 결정합니다.
메모리 부여 제한 시간에 도달하면 쿼리가 항상 실패하지는 않습니다. 쿼리가 너무 많은 동시 쿼리가 실행 중인 경우에만 실패합니다. 그렇지 않으면 쿼리가 최소 메모리 부여만 가져와 쿼리 성능이 저하될 수 있습니다.
MAX_DOP = value
병렬 쿼리 실행에 대한 최대 병렬 처리 수준(MAXDOP
)을 지정합니다. 허용되는 value의 범위는 0에서 64까지입니다.
value의 기본 설정 0은 전역 설정을 사용합니다.
자세한 내용은 MAXDOP참조하세요.
GROUP_MAX_REQUESTS = value
작업 그룹에서 실행할 수 있는 최대 동시 요청 수를 지정합니다. value는 0 또는 양의 정수여야 합니다. 값의 기본 설정은 0이며, 무제한 요청을 허용합니다. 최대 동시 요청에 도달하면 해당 그룹의 세션을 만들 수 있지만 동시 요청 수가 지정된 값 아래로 떨어질 때까지 대기 상태에 배치됩니다.
USING { pool_name | [기본값] }
워크로드 그룹을 pool_name식별된 사용자 정의 리소스 풀 또는 default
리소스 풀과 연결합니다.
pool_name 제공되지 않거나 USING
인수가 지정되지 않은 경우 워크로드 그룹은 기본 제공 default
풀과 연결됩니다.
default
예약어이며 USING
지정된 경우 대괄호([]
) 또는 따옴표(""
)로 묶어야 합니다.
기본 제공 리소스 풀 및 워크로드 그룹은 default
같은 모든 소문자 이름을 사용합니다. 대/소문자 구분 데이터 정렬을 사용하는 서버에서 소문자 default
사용합니다. 대/소문자를 구분하지 않는 데이터 정렬이 있는 서버는 default
, Default
및 DEFAULT
동일한 값으로 처리합니다.
EXTERNAL external_pool_name | [기본값]
적용 대상: SQL Server 2016(13.x) 이상
작업 그룹은 외부 리소스 풀을 지정할 수 있습니다. 워크로드 그룹을 정의하고 다음 두 풀과 연결할 수 있습니다.
- 데이터베이스 엔진 워크로드에 대한 리소스 풀입니다.
- 외부 프로세스에 대한 외부 리소스 풀. 자세한 내용은 sp_execute_external_script참조하세요.
설명
자세한 내용은 Resource Governor 및 Resource Governor 워크로드 그룹참조하세요.
MAXDOP
지정된 쿼리의 경우 유효한 MAXDOP
다음과 같이 결정됩니다.
- 쿼리 힌트로
MAXDOP
작업 그룹MAX_DOP
설정을 초과하지 않는 한 적용됩니다. - 쿼리 힌트로
MAXDOP
항상max degree of parallelism
서버 구성을 재정의합니다. 자세한 내용은 Server 구성을 참조하세요. 최대 병렬 처리 수준. - 워크로드 그룹
MAX_DOP
max degree of parallelism
서버 구성 및MAXDOP
데이터베이스 범위 구성재정의합니다.
MAXDOP
제한은 작업별로 설정됩니다.
요청별 또는 쿼리 제한별로 수행되지 않습니다. 병렬 쿼리를 실행하는 동안 단일 요청은 스케줄러할당된 여러 작업을 생성할 수 있습니다. 자세한 내용은 스레드 및 작업 아키텍처 가이드참조하세요.
쿼리가 컴파일 시간(MAXDOP = 1
)에 직렬로 표시되면 워크로드 그룹 또는 서버 구성 설정에 관계없이 런타임에 병렬 처리로 실행할 수 없습니다. 쿼리에 대해 MAXDOP
결정된 후에는 메모리 압력으로 인해 낮출 수 있습니다. 워크로드 그룹 재구성은 메모리 부여 큐에서 대기 중인 쿼리에 영향을 주지 않습니다.
인덱스 만들기
성능상의 이유로 인덱스 만들기는 처음에 부여된 것보다 더 많은 메모리 작업 영역을 사용할 수 있습니다. 리소스 관리자는 이 특별 처리를 지원합니다. 그러나 초기 권한 부여 및 추가 메모리 부여는 워크로드 그룹 및 리소스 풀 설정에 의해 제한됩니다.
분할된 테이블에서 정렬되지 않은 인덱스를 만드는 데 사용되는 메모리는 관련된 파티션 수에 비례합니다. 필요한 총 메모리가 REQUEST_MAX_MEMORY_GRANT_PERCENT
워크로드 그룹 설정에 의해 적용되는 쿼리당 제한을 초과하면 인덱스 생성이 실패할 수 있습니다.
default
워크로드 그룹을 사용하면 쿼리가 이전 버전과의 호환성을 위해 시작하는 데 필요한 최소 메모리로 쿼리당 제한을 초과할 수 있으므로 default
리소스 풀에 충분한 총 메모리가 있는 경우 default
워크로드 그룹을 사용하여 동일한 인덱스를 만들 수 있습니다.
사용 권한
CONTROL SERVER
권한이 필요합니다.
예제
newReports
리소스 풀에 default
이라는 워크로드 그룹을 만들고 최대 메모리 부여, 요청에 대한 최대 CPU 시간 및 MAXDOP
제한합니다.
CREATE WORKLOAD GROUP newReports
WITH (
REQUEST_MAX_MEMORY_GRANT_PERCENT = 2.5,
REQUEST_MAX_CPU_TIME_SEC = 100,
MAX_DOP = 4
)
USING [default];
관련 콘텐츠
- 자습서: 리소스 관리자 구성 예제 및 모범 사례
- 리소스 관리자
- Resource Governor 워크로드 그룹
- 워크로드 그룹 만들기
- ALTER WORKLOAD GROUP
- 워크로드 그룹 삭제
- 리소스 풀 만들기
- ALTER RESOURCE POOL
- 리소스 풀 삭제
- ALTER RESOURCE GOVERNOR
* Azure Synapse
Analytics *
Azure Synapse Analytics
워크로드 그룹을 만듭니다. 워크로드 그룹은 요청 세트에 대한 컨테이너로, 시스템에서 워크로드 관리를 구성하는 방법에 대한 기본 사항에 해당합니다. 워크로드 그룹은 워크로드 격리를 위해 리소스를 예약하고, 리소스를 포함하고, 요청별로 리소스를 정의하고, 실행 규칙을 따르도록 하는 기능을 제공합니다. 문이 완료되면 설정이 적용됩니다.
CREATE WORKLOAD GROUP group_name
WITH
( MIN_PERCENTAGE_RESOURCE = value
, CAP_PERCENTAGE_RESOURCE = value
, REQUEST_MIN_RESOURCE_GRANT_PERCENT = value
[ [ , ] REQUEST_MAX_RESOURCE_GRANT_PERCENT = value ]
[ [ , ] IMPORTANCE = { LOW | BELOW_NORMAL | NORMAL | ABOVE_NORMAL | HIGH } ]
[ [ , ] QUERY_EXECUTION_TIMEOUT_SEC = value ] )
[ ; ]
group_name
워크로드 그룹을 식별하는 이름을 지정합니다.
group_name은 sysname입니다. 최대 128자까지 가능하며 인스턴스 내에서 고유해야 합니다.
MIN_PERCENTAGE_RESOURCE = value
이 워크로드 그룹에 대해 다른 작업 그룹과 공유되지 않도록 보장된 최소 리소스 할당을 지정합니다. 메모리만 이 매개 변수로 제어되는 리소스입니다.
value는 0에서 100 사이의 정수 범위입니다. 모든 워크로드 그룹에서 min_percentage_resource의 합계는 100을 초과할 수 없습니다. min_percentage_resource 값은 cap_percentage_resource보다 클 수 없습니다. 서비스 수준에 따라 허용되는 최소 유효 값이 있습니다. 자세한 내용은 유효 값을 참조하세요.
CAP_PERCENTAGE_RESOURCE = value
워크로드 그룹의 모든 요청에 대한 최대 리소스 사용률을 지정합니다. CPU와 메모리 리소스 둘 다 이 매개 변수로 제한됩니다. 허용되는 정수 값의 범위는 1에서 100까지입니다. cap_percentage_resource 값은 min_percentage_resource보다 커야 합니다. 다른 워크로드 그룹에서 min_percentage_resource가 0보다 크게 구성된 경우 cap_percentage_resource의 유효 값이 줄어들 수 있습니다.
REQUEST_MIN_RESOURCE_GRANT_PERCENT = value
요청별로 할당된 최소 리소스 크기를 설정합니다. 메모리만 이 매개 변수로 제어되는 리소스입니다.
value는 0.75에서 100.00 사이의 10 진수 범위에 속하는 필수 매개 변수입니다. request_min_resource_grant_percent 값은 0.25의 배수여야 하고 min_percentage_resource의 요소여야 하며, cap_percentage_resource보다 작아야 합니다. 서비스 수준에 따라 허용되는 최소 유효 값이 있습니다. 자세한 내용은 유효 값을 참조하세요.
다음은 그 예입니다.
CREATE WORKLOAD GROUP wgSample
WITH
( MIN_PERCENTAGE_RESOURCE = 26 -- integer value
, REQUEST_MIN_RESOURCE_GRANT_PERCENT = 3.25 -- factor of 26 (guaranteed a minimum of 8 concurrency)
, CAP_PERCENTAGE_RESOURCE = 100 )
리소스 클래스에 사용되는 값을 request_min_resource_grant_percent에 대한 지침으로 간주합니다. 다음 표에서는 Gen2에 대한 리소스 할당을 포함합니다.
리소스 클래스 | 리소스 비율 |
---|---|
Smallrc | 3% |
Mediumrc | 10% |
Largerc | 22% |
Xlargerc | 70% |
REQUEST_MAX_RESOURCE_GRANT_PERCENT = value
요청별로 할당된 최대 리소스 크기를 설정합니다. 메모리만 이 매개 변수로 제어되는 리소스입니다.
value는 기본값이 request_min_resource_grant_percent와 같은 선택적 10진수 매개 변수입니다.
value는 request_min_resource_grant_percent보다 크거나 같아야 합니다. request_max_resource_grant_percent 값이 request_min_resource_grant_percent보다 크고, 시스템 리소스를 사용할 수 있는 경우 추가 리소스가 요청에 할당됩니다.
IMPORTANCE = { LOW | BELOW_NORMAL | NORMAL | ABOVE_NORMAL | HIGH }
워크로드 그룹에 대한 요청의 기본 중요도를 지정합니다. 중요도는 다음 중 하나이며 NORMAL이 기본값입니다.
- LOW
- BELOW_NORMAL
- NORMAL(기본값)
- ABOVE_NORMAL
- HIGH
워크로드 그룹에 설정된 중요도는 워크로드 그룹의 모든 요청에 대한 기본 중요도입니다. 또한 사용자는 분류자 수준에서 중요도를 설정할 수 있으며 이 중요도로 워크로드 그룹 중요도 설정을 재정의할 수 있습니다. 이렇게 하면 워크로드 그룹 내에서 요청의 중요도를 차별화하여 예약되지 않은 리소스에 더 빠르게 액세스할 수 있습니다. 워크로드 그룹의 min_percentage_resource 합계가 100보다 작으면 예약되지 않은 리소스가 중요도를 기준으로 할당됩니다.
QUERY_EXECUTION_TIMEOUT_SEC = value
쿼리가 취소되기 전에 실행될 수 있는 최대 시간(초)을 지정합니다.
value는 0 또는 양의 정수여야 합니다. value의 기본 설정인 0은 쿼리 시간이 제한되지 않음을 의미합니다. QUERY_EXECUTION_TIMEOUT_SEC는 쿼리가 큐에 대기할 때가 아니라 실행 중 상태로 전환된 후 계산됩니다.
설명
리소스 클래스에 해당하는 워크로드 그룹은 이전 버전과의 호환성을 위해 자동으로 만들어집니다. 이러한 시스템 정의 워크로드 그룹은 삭제할 수 없습니다. 추가로 8개의 사용자 정의 워크로드 그룹을 만들 수 있습니다.
min_percentage_resource
가 0보다 큰 작업 그룹이 생성되면 CREATE WORKLOAD GROUP
문은 작업 그룹을 만들 충분한 리소스가 있을 때까지 큐에 대기합니다.
유효 값
min_percentage_resource
, cap_percentage_resource
, request_min_resource_grant_percent
및 request_max_resource_grant_percent
매개 변수에는 현재 서비스 수준의 컨텍스트에서 조정된 유효 값과 다른 작업 그룹의 구성이 포함됩니다.
서비스 수준에 따라 쿼리당 최소 리소스가 필요하기 때문에 request_min_resource_grant_percent
매개 변수에는 유효한 값이 있습니다. 예를 들어 가장 낮은 서비스 수준인 DW100c에서는 요청당 최소 25% 리소스가 필요합니다. 작업 그룹이 3% request_min_resource_grant_percent
및 request_max_resource_grant_percent
로 구성된 경우 인스턴스가 시작될 때 두 매개 변수의 유효 값이 25%로 조정됩니다. 인스턴스가 DW1000c로 확장되는 경우 두 매개 변수에 구성되는 유효 값은 3%입니다. 해당 서비스 수준에 지원되는 최소 값이 3%이기 때문입니다. 인스턴스가 DW1000c보다 높게 확장되는 경우 두 매개 변수에 대해 구성되는 유효 값은 3%로 유지됩니다. 각 서비스 수준의 유효 값에 대한 자세한 내용은 아래 표를 참조하세요.
서비스 수준 | REQUEST_MIN_RESOURCE_GRANT_PERCENT에 대한 가장 낮은 유효 값 | 최대 동시 쿼리 수 |
---|---|---|
DW100c | 25% | 4 |
DW200c | 12.5% | 8 |
DW300c | 8% | 12 |
DW400c | 6.25% | 16 |
DW500c | 5% | 20 |
DW1000c | 3% | 32 |
DW1500c | 3% | 32 |
DW2000c | 2% | 48 |
DW2500c | 2% | 48 |
DW3000c | 1.5% | 64 |
DW5000c | 1.5% | 64 |
DW6000c | 0.75% | 128 |
DW7500c | 0.75% | 128 |
DW10000c | 0.75% | 128 |
DW15000c | 0.75% | 128 |
DW30000c | 0.75% | 128 |
min_percentage_resource
매개 변수는 유효 request_min_resource_grant_percent
보다 크거나 같아야 합니다.
min_percentage_resource
가 유효 min_percentage_resource
보다 작게 구성된 작업 그룹은 값이 런타임에 0으로 조정됩니다. 이 경우 min_percentage_resource
에 대해 구성된 리소스를 모든 작업 그룹에서 공유할 수 있습니다. 예를 들어 DW1000c에서 10%의 wgAdHoc
가 실행되는 작업 그룹 min_percentage_resource
은 유효 min_percentage_resource
가 10%입니다(3%는 DW1000c에서 지원되는 최솟값임). DW100c에서 wgAdhoc
의 유효 min_percentage_resource는 0%입니다.
wgAdhoc
에 대해 구성된 10%는 모든 작업 그룹에서 공유됩니다.
또한 cap_percentage_resource
매개 변수는 유효 값을 가집니다. 작업 그룹 wgAdhoc
이 100%의 cap_percentage_resource
로 구성되고 다른 작업 그룹 wgDashboards
가 25%의 min_percentage_resource
로 생성된 경우 cap_percentage_resource
의 유효 wgAdhoc
는 75%가 됩니다.
워크로드 그룹에 대한 런타임 값을 이해하는 가장 쉬운 방법은 시스템 보기 sys.dm_workload_management_workload_groups_stats를 쿼리하는 것입니다.
사용 권한
CONTROL DATABASE
권한이 필요합니다.