SQL Server Worker Thread 기본 계산
· Version : SQL Server
SQL Server 2017부터는 소규모 환경을 고려하여 SQL Server의 기본 worker thread 수가 약간 변경되었다. 소규모 환경에서 SQL Server를 실행하는 경우 SQL Server는 worker thread를 줄인다. X64 설치의 경우 sp_configure ‘max worker threads’ 값을 0으로 설정하면 SQL Server는 아래 계산 공식을 사용한다.
Default |
512 |
Small Environment |
256 |
소규모 환경에서는 SQL Server는 항상 worker thread 256을 사용한다. 더 큰 환경에서 실행하면 worker thread는 512가 기본값이며 CPU 수에 따라 조정된다.
CPU가 4개보다 많으면 worker thread 수는512 까지 증가하며, CPU 수에 따라32또는 16씩 증가하여 최대 512까지 증가한다. 만약 시스템에 64개 이상의 CPU가 있으면 추가 worker thread는 CPU당 32 worker thread가 증가한다.
이러한 설계는 CPU 및 메모리 리소스가 적은 소규모 환경 및 더 큰 CPU 및 메모리를 사용하는 시스템을 고려한다. worker thread는 보이는 스케줄러에만 적용된다. 숨겨진 스케줄러 및 DAC (Dedicated Admin Connection) 스케줄러는 계산에 영향을 받지 않는다.
[참고자료]
https://blogs.msdn.microsoft.com/bobsql/2019/02/10/sql-server-worker-thread-default-calculation/
2019-09-17/ Sungwook Kang / http://sungwookkang.com
SQL Server2017, worker thread
'SQL Server > SQL Server Tip' 카테고리의 다른 글
SQL Server 2019 Log Writer Workers (0) | 2019.09.19 |
---|---|
SQL Server Login Timeout 디버깅 (0) | 2019.09.19 |
SQL Linux의 fsync 및 버퍼된 IO (버퍼된 쓰기중 오류가 발생하였을때 파일은 유효할까?) (0) | 2019.09.17 |
SQL Server와 SQL Linux에서 인스턴스 파일 초기화 차이점 (0) | 2019.09.14 |
BCP 실행시 동일 세션에서 여러개의 BULK INSERT 문으로 표시되는 이유 (0) | 2019.09.13 |