다음을 통해 공유


sys.dm_db_wait_stats (Azure SQL 데이터베이스)

적용 대상: Azure SQL Database Azure SQL Managed Instance

작업 중 실행 중인 스레드로 인해 발생한 모든 대기에 대한 정보를 반환합니다. 이 집계된 보기를 사용하여 Azure SQL Database 및 특정 쿼리 및 일괄 처리와 관련된 성능 문제를 진단할 수 있습니다.

쿼리 실행 중 특정 유형의 대기 시간은 쿼리 내에서 병목 상태 또는 중단 지점을 나타낼 수 있습니다. 마찬가지로 높은 대기 시간이나 서버 전체의 대기 횟수가 서버 인스턴스 내의 쿼리 상호 작용에서 병목 또는 핫 스폿을 나타낼 수 있습니다. 예를 들어 잠금 대기는 쿼리별 데이터 경합을 나타냅니다. 페이지 IO 래치 대기는 느린 IO 응답 시간을 나타냅니다. 페이지 래치 업데이트 대기는 잘못된 파일 레이아웃을 나타냅니다.

열 이름 데이터 형식 설명
wait_type nvarchar(60) 대기 유형의 이름입니다. 자세한 내용은 이 항목의 뒷부분에 있는 대기 유형을 참조하세요.
waiting_tasks_count bigint 이 대기 유형의 대기 수입니다. 이 카운터는 각 대기가 시작될 때 증가합니다.
wait_time_ms bigint 이 대기 유형에 대한 총 대기 시간(밀리초)입니다. 이 시간은 signal_wait_time_ms를 포함합니다.
max_wait_time_ms bigint 이 대기 유형의 최대 대기 시간입니다.
signal_wait_time_ms bigint 대기 중인 스레드가 신호를 받은 시간과 실행이 시작된 시간 간의 차이입니다.

설명

  • 이 동적 관리 뷰에는 현재 데이터베이스에 대한 데이터만 표시됩니다.

  • 이 동적 관리 뷰는 완료된 대기 시간을 보여 줍니다. 현재 대기는 표시되지 않습니다.

  • 카운터는 데이터베이스를 이동하거나 오프라인으로 전환할 때마다 0으로 다시 설정됩니다.

  • SQL Server 작업자 스레드는 다음 중 어느 것이라도 true이면 대기 중인 것으로 간주되지 않습니다.

    • 리소스를 사용할 수 있게 됩니다.

    • 큐가 비어 있지 않습니다.

    • 외부 프로세스가 완료됩니다.

참고 항목

이러한 통계는 SQL Database 장애 조치(failover) 이벤트 후에 유지되지 않으며 통계가 마지막으로 다시 설정되거나 데이터베이스 엔진이 시작된 이후 모든 데이터가 누적됩니다. sqlserver_start_time sys.dm_os_sys_info 열을 사용하여 마지막 데이터베이스 엔진 시작 시간을 찾습니다.

사용 권한

데이터베이스에 대한 VIEW DATABASE STATE 권한이 필요합니다.

대기 유형

리소스 대기
리소스 대기는 다른 작업자가 사용하고 있거나 아직 제공되지 않아서 사용할 수 없는 리소스에 대한 액세스를 요청하는 경우에 발생합니다. 리소스 대기의 예로는 잠금, 래치, 네트워크 및 디스크 I/O 대기가 있습니다. 잠금 및 래치 대기는 동기화 개체에서 대기합니다.

큐 대기
큐 대기는 작업자가 유휴 상태일 때 작업이 할당되기를 기다리는 경우에 발생합니다. 큐 대기는 교착 상태 모니터 및 삭제된 레코드 정리 작업과 같은 시스템 백그라운드 작업에서 가장 일반적으로 표시됩니다. 이러한 작업은 작업 요청이 작업 큐에 배치될 때까지 기다립니다. 큐에 새 패킷이 배치되지 않은 경우에도 큐 대기가 주기적으로 활성화될 수 있습니다.

외부 대기
SQL Server 작업자가 확장 저장 프로시저 호출 또는 연결된 서버 쿼리와 같은 외부 이벤트가 완료되기를 기다리는 경우 외부 대기가 발생합니다. 차단 문제를 진단할 때 작업자가 일부 외부 코드를 적극적으로 실행 중일 수 있으므로 외부 대기가 항상 작업자가 유휴 상태임을 의미하지는 않습니다.

스레드가 더 이상 대기하지 않지만 스레드는 즉시 실행을 시작할 필요가 없습니다. 이러한 스레드는 먼저 실행 가능한 작업자의 큐에 배치되고 스케줄러에서 양자가 실행될 때까지 기다려야 하기 때문입니다.

SQL Server에서 대기 시간 카운터는 bigint 값이므로 이전 버전의 SQL Server에서 해당하는 카운터만큼 롤오버에 대응하는 경향이 없습니다.

다음 표에서는 태스크에서 발생하는 대기 유형을 나열합니다.

대기 유형 설명
ABR 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
ASSEMBLY_LOAD 어셈블리 로드에 대한 단독 액세스 중에 발생합니다.
ASYNC_DISKPOOL_LOCK 파일 만들기 또는 초기화와 같은 작업을 수행하는 병렬 스레드를 동기화하려고 할 때 발생합니다.
ASYNC_IO_COMPLETION 작업이 I/O가 완료되길 기다리는 경우에 발생합니다.
ASYNC_NETWORK_IO 태스크가 네트워크 뒤에서 차단되는 경우에 네트워크 쓰기 중에 발생합니다. 클라이언트가 서버의 데이터를 처리하고 있는지 확인합니다.
AUDIT_GROUPCACHE_LOCK 특수 캐시에 대한 액세스를 제어하는 잠금에 대한 대기가 있을 때 발생합니다. 캐시에는 각 감사 작업 그룹을 감사하는 데 사용되는 감사에 대한 정보가 포함되어 있습니다.
AUDIT_LOGINCACHE_LOCK 특수 캐시에 대한 액세스를 제어하는 잠금에 대한 대기가 있을 때 발생합니다. 캐시에는 로그인 감사 작업 그룹을 감사하는 데 사용되는 감사에 대한 정보가 포함되어 있습니다.
AUDIT_ON_DEMAND_TARGET_LOCK 감사와 관련된 확장 이벤트 대상의 단일 초기화를 위한 잠금을 기다리는 경우에 발생합니다.
AUDIT_XE_SESSION_MGR 감사 관련 확장 이벤트 세션의 시작 및 중지를 동기화하는 데 사용되는 잠금에 대한 대기가 있을 때 발생합니다.
BACKUP 백업 처리의 일부로 작업이 차단될 때 발생합니다.
BACKUP_OPERATOR 태스크가 테이프 탑재를 대기하는 경우에 발생합니다.
BACKUPBUFFER 백업 태스크가 데이터를 대기하거나 데이터를 저장할 버퍼를 기다리는 경우에 발생합니다. 태스크가 테이프 탑재를 기다리는 경우를 제외하고 이 형식은 일반적이지 않습니다.
BACKUPIO 백업 태스크가 데이터를 대기하거나 데이터를 저장할 버퍼를 기다리는 경우에 발생합니다. 태스크가 테이프 탑재를 기다리는 경우를 제외하고 이 형식은 일반적이지 않습니다.
BACKUPTHREAD 태스크가 백업 작업이 완료되길 기다리는 동안 발생합니다. 대기 시간은 몇 분에서 몇 시간까지 길 수 있습니다. 대기 중인 작업이 I/O 프로세스에 있는 경우 이 형식은 문제를 나타내지 않습니다.
BAD_PAGE_PROCESS 백그라운드 의심 페이지 로거가 5초 이상 실행되지 않도록 하려고 할 때 발생합니다. 의심되는 페이지가 너무 많아서 로거가 자주 실행됩니다.
BROKER_CONNECTION_RECEIVE_TASK 연결 엔드포인트에서 메시지를 받기 위한 액세스를 대기하는 경우에 발생합니다. 엔드포인트에 대한 수신 액세스가 직렬화됩니다.
BROKER_ENDPOINT_STATE_MUTEX Service Broker 연결 엔드포인트의 상태에 액세스하기 위한 경합이 있을 때 발생합니다. 변경 내용의 상태에 대한 액세스는 직렬화됩니다.
BROKER_EVENTHANDLER 작업이 Service Broker의 기본 이벤트 처리기에서 대기 중일 때 발생합니다. 이 작업은 매우 짧게 발생합니다.
BROKER_INIT 각 활성 데이터베이스에서 Service Broker를 초기화할 때 발생합니다. 이 작업은 자주 발생하지 않습니다.
BROKER_MASTERSTART 작업이 Service Broker의 기본 이벤트 처리기가 시작되기를 기다리는 경우에 발생합니다. 이 작업은 매우 짧게 발생합니다.
BROKER_RECEIVE_WAITFOR RECEIVE WAITFOR가 대기 중일 때 발생합니다. 이는 메시지를 받을 준비가 되지 않은 경우에 일반적입니다.
BROKER_REGISTERALLENDPOINTS Service Broker 연결 엔드포인트를 초기화하는 동안 발생합니다. 이 작업은 매우 짧게 발생합니다.
BROKER_SERVICE 대상 서비스와 연결된 Service Broker 대상 목록을 업데이트하거나 우선 순위를 다시 지정하면 발생합니다.
BROKER_SHUTDOWN Service Broker의 계획된 종료가 있을 때 발생합니다. 이 경우 매우 짧게 발생 해야 합니다.
BROKER_TASK_STOP Service Broker 큐 작업 처리기가 작업을 종료하려고 할 때 발생합니다. 상태 검사는 직렬화되며 실행 중 상태여야 합니다.
BROKER_TO_FLUSH Service Broker 지연 플러시가 메모리 내 전송 개체를 작업 테이블로 플러시할 때 발생합니다.
BROKER_TRANSMITTER Service Broker 전송기가 작업을 기다리고 있을 때 발생합니다.
BUILTIN_HASHKEY_MUTEX 내부 데이터 구조가 초기화되는 동안 인스턴스가 시작되면 발생할 수 있습니다. 데이터 구조가 초기화되면 다시 발생하지 않습니다.
CHECK_PRINT_RECORD 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
CHECKPOINT_QUEUE 검사점 태스크가 다음 검사점 요청을 기다리는 동안 발생합니다.
CHKPT 검사점 스레드에 시작할 수 있음을 알리기 위해 서버 시작 시 발생합니다.
CLEAR_DB 데이터베이스 열기 또는 닫기 등 데이터베이스의 상태를 변경하는 작업 중에 발생합니다.
CLR_AUTO_EVENT 태스크가 현재 CLR(공용 언어 런타임) 실행을 수행하고 특정 자동 실행이 시작될 때까지 대기하는 경우에 발생합니다. 긴 대기는 일반적이며 문제를 나타내지 않습니다.
CLR_CRST 태스크가 현재 CLR 실행을 수행하고 다른 태스크에서 현재 사용 중인 작업의 중요한 섹션을 입력하기 위해 대기하는 경우에 발생합니다.
CLR_JOIN 태스크가 현재 CLR 실행 중이며 다른 작업이 끝날 때까지 대기하는 경우에 발생합니다. 이 대기 상태는 태스크 간에 조인이 있는 경우에 발생합니다.
CLR_MANUAL_EVENT 태스크가 현재 CLR 실행 중이며 특정 수동 이벤트가 시작될 때까지 대기하는 경우에 발생합니다.
CLR_MEMORY_SPY CLR에서 가져온 모든 가상 메모리 할당을 기록하는 데 사용되는 데이터 구조에 대한 잠금 획득 대기 중에 발생합니다. 데이터 구조는 병렬 액세스가 있는 경우 무결성을 유지하기 위해 잠깁니다.
CLR_MONITOR 태스크가 현재 CLR 실행을 수행하고 모니터에 대한 잠금을 얻기 위해 대기하는 경우에 발생합니다.
CLR_RWLOCK_READER 태스크가 현재 CLR 실행을 수행하고 판독기 잠금을 기다리는 경우에 발생합니다.
CLR_RWLOCK_WRITER 태스크가 현재 CLR 실행을 수행하고 기록기 잠금을 기다리는 경우에 발생합니다.
CLR_SEMAPHORE 태스크가 현재 CLR 실행을 수행하고 세마포를 기다리는 경우에 발생합니다.
CLR_TASK_START CLR 작업이 시작을 완료할 때까지 기다리는 동안 발생합니다.
CLRHOST_STATE_ACCESS CLR 호스팅 데이터 구조에 대한 단독 액세스를 얻기 위해 대기하는 경우에 발생합니다. 이 대기 유형은 CLR 런타임을 설정하거나 해제하는 동안 발생합니다.
CMEMTHREAD 태스크가 스레드로부터 안전한 메모리 개체를 기다리는 경우에 발생합니다. 동일한 메모리 개체에서 메모리를 할당하려고 하는 여러 작업으로 인해 경합이 발생하는 경우 대기 시간이 증가할 수 있습니다.
CXPACKET 쿼리 프로세서 교환 반복기를 동기화하려고 할 때 발생합니다. 이 대기 유형에 대한 경합이 문제가 될 경우 병렬 처리 수준을 낮추는 것이 좋습니다.
CXROWSET_SYNC 병렬 범위 검색 중에 발생합니다.
DAC_INIT 관리자 전용 연결이 초기화되는 동안 발생합니다.
DBMIRROR_DBM_EVENT 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
DBMIRROR_DBM_MUTEX 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
DBMIRROR_EVENTS_QUEUE 데이터베이스 미러링이 이벤트가 처리되기를 기다리는 경우에 발생합니다.
DBMIRROR_SEND 태스크가 네트워크 계층의 통신 백로그가 지워져서 메시지를 보낼 수 있을 때까지 대기하는 경우에 발생합니다. 통신 계층이 오버로드되기 시작하고 데이터베이스 미러링 데이터 처리량에 영향을 줍니다.
DBMIRROR_WORKER_QUEUE 데이터베이스 미러링 작업자 작업이 더 많은 작업을 기다리고 있음을 나타냅니다.
DBMIRRORING_CMD 태스크가 로그 레코드가 디스크로 플러시될 때까지 대기하는 경우에 발생합니다. 이 대기 상태는 오랜 시간 동안 유지될 것으로 예상됩니다.
DEADLOCK_ENUM_MUTEX 교착 상태 모니터 sys.dm_os_waiting_tasks 가 SQL Server에서 동시에 여러 교착 상태 검색을 실행하지 않는지 확인하려고 할 때 발생합니다.
DEADLOCK_TASK_SEARCH 이 리소스의 대기 시간이 클수록 서버가 쿼리 sys.dm_os_waiting_tasks를 실행 중이며 이러한 쿼리는 교착 상태 모니터가 교착 상태 검색을 실행하지 못하도록 차단하고 있음을 나타냅니다. 이 대기 유형은 교착 상태 모니터에서만 사용됩니다. 사용 DEADLOCK_ENUM_MUTEX 위에 있는 sys.dm_os_waiting_tasks 쿼리입니다.
DEBUG 내부 동기화를 위해 Transact-SQL 및 CLR 디버깅 중에 발생합니다.
DISABLE_VERSIONING SQL Server가 버전 트랜잭션 관리자를 폴링하여 가장 빠른 활성 트랜잭션의 타임스탬프가 상태가 변경되기 시작한 시점의 타임스탬프보다 늦는지 여부를 확인할 때 발생합니다. 이 경우 ALTER DATABASE 문을 실행하기 전에 시작된 모든 스냅샷 트랜잭션이 완료됩니다. 이 대기 상태는 SQL Server가 ALTER DATABASE 문을 사용하여 버전 관리를 사용하지 않도록 설정하는 경우에 사용됩니다.
DISKIO_SUSPEND 외부 백업이 활성 상태일 때 태스크가 파일에 액세스하기 위해 대기하는 경우에 발생합니다. 대기 중인 모든 사용자 프로세스에 대해 보고됩니다. 사용자 프로세스당 5개보다 큰 개수는 외부 백업을 완료하는 데 너무 많은 시간이 걸리고 있음을 나타낼 수 있습니다.
DISPATCHER_QUEUE_SEMAPHORE 디스패처 풀의 스레드가 더 많은 작업이 처리되기를 기다리는 경우에 발생합니다. 이 대기 유형에 대한 대기 시간은 디스패처가 유휴 상태일 때 증가할 것으로 예상됩니다.
DLL_LOADING_MUTEX XML 파서 DLL이 로드되도록 기다리는 동안 한 번 발생합니다.
DROPTEMP 이전 시도가 실패한 경우 임시 개체를 삭제하려는 시도 사이에 발생합니다. 대기 기간은 실패할 때마다 기하급수적으로 증가합니다.
DTC 태스크가 상태 전환을 관리하는 데 사용되는 이벤트를 대기할 때 발생합니다. 이 상태는 SQL Server가 MS DTC 서비스를 사용할 수 없게 되었다는 알림을 받은 후 MS DTC(Microsoft Distributed Transaction Coordinator) 트랜잭션의 복구가 발생하는 시기를 제어합니다.

또한 이 상태는 SQL Server에서 MS DTC 트랜잭션의 커밋을 시작하고 SQL Server가 MS DTC 커밋이 완료되기를 기다리는 경우 대기 중인 작업을 설명합니다.
DTC_ABORT_REQUEST 세션이 MS DTC 트랜잭션의 소유권을 가져오기를 기다리는 동안 MS DTC 작업자 세션에서 발생합니다. MS DTC가 트랜잭션의 소유권을 획득한 후에는 세션이 트랜잭션을 롤백할 수 있습니다. 일반적으로 세션은 트랜잭션을 사용하고 있는 다른 세션을 기다립니다.
DTC_RESOLVE 복구 태스크가 트랜잭션의 결과물을 쿼리할 수 있도록 데이터베이스 간 트랜잭션에서 master 데이터베이스를 대기하는 경우에 발생합니다.
DTC_STATE 태스크가 내부 MS DTC 전역 상태 개체의 변경 내용을 보호하는 이벤트를 대기할 때 발생합니다. 이 상태는 매우 짧은 기간 동안 유지되어야 합니다.
DTC_TMDOWN_REQUEST SQL Server에서 MS DTC 서비스를 사용할 수 없다는 알림을 받으면 MS DTC 작업자 세션에서 발생합니다. 먼저 작업자는 MS DTC 복구 프로세스가 시작될 때까지 기다립니다. 그런 다음 작업자는 작업자가 작업 중인 분산 트랜잭션의 결과를 얻기 위해 기다립니다. MS DTC 서비스와의 연결이 다시 설정될 때까지 이 작업이 계속될 수 있습니다.
DTC_WAITFOR_OUTCOME 복구 태스크가 MS DTC가 활성 상태가 될 때까지 대기하여 준비된 트랜잭션을 확인할 때 발생합니다.
DUMP_LOG_COORDINATOR 주 태스크가 하위 작업이 데이터를 생성할 때까지 대기하는 경우에 발생합니다. 일반적으로 이 상태는 발생하지 않습니다. 긴 대기는 예기치 않은 막힘을 나타냅니다. 하위 작업을 조사해야 합니다.
DUMPTRIGGER 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
EC 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
EE_PMOLOCK 문을 실행하는 동안 특정 유형의 메모리 할당을 동기화하는 동안 발생합니다.
EE_SPECPROC_MAP_INIT 내부 프로시저 해시 테이블을 만드는 동안 발생합니다. 이 대기는 SQL Server 인스턴스가 시작된 후 해시 테이블에 처음 액세스하는 동안에만 발생할 수 있습니다.
ENABLE_VERSIONING SQL Server가 이 데이터베이스의 모든 업데이트 트랜잭션이 완료될 때까지 기다린 후 스냅샷 격리 허용 상태로 전환할 준비가 된 데이터베이스를 선언할 때 발생합니다. 이 상태는 SQL Server가 ALTER DATABASE 문을 사용하여 스냅샷 격리를 사용하도록 설정하는 경우에 사용됩니다.
ERROR_REPORTING_MANAGER 여러 동시 오류 로그 초기화를 동기화하는 동안 발생합니다.
EXCHANGE 병렬 쿼리 중에 쿼리 프로세서 교환 반복기에서 동기화하는 동안 발생합니다.
EXECSYNC 교환 반복기와 관련이 없는 영역에서 쿼리 프로세서에서 동기화하는 동안 병렬 쿼리 중에 발생합니다. 이러한 영역의 예로는 비트맵, 큰 이진 개체(LOB) 및 스풀 반복기가 있습니다. LOB는 이 대기 상태를 자주 사용할 수 있습니다.
EXECUTION_PIPE_EVENT_INTERNAL 연결 컨텍스트를 통해 제출되는 일괄 처리 실행의 생산자와 소비자 부분 간의 동기화 중에 발생합니다.
FAILPOINT 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
FCB_REPLICA_READ 스냅샷(또는 DBCC에서 만든 임시 스냅샷) 스파스 파일의 읽기가 동기화될 때 발생합니다.
FCB_REPLICA_WRITE 스냅샷(또는 DBCC에서 만든 임시 스냅샷) 스파스 파일로 페이지를 푸시하거나 끌어당기는 작업이 동기화될 때 발생합니다.
FS_FC_RWLOCK 다음 중 하나를 수행하기 위해 FILESTREAM 가비지 수집기가 대기하는 경우에 발생합니다.

가비지 수집을 사용하지 않도록 설정합니다(백업 및 복원에서 사용).

FILESTREAM 가비지 수집기의 한 주기 실행
FS_GARBAGE_COLLECTOR_SHUTDOWN FILESTREAM 가비지 수집기가 정리 작업이 완료되기를 기다리는 경우에 발생합니다.
FS_HEADER_RWLOCK FILESTREAM 헤더 파일(Filestream.hdr)의 콘텐츠를 읽거나 업데이트하기 위해 FILESTREAM 데이터 컨테이너의 FILESTREAM 헤더에 대한 액세스 권한을 얻기 위해 대기하는 경우에 발생합니다.
FS_LOGTRUNC_RWLOCK 다음 중 하나를 수행하기 위해 FILESTREAM 로그 잘림에 대한 액세스를 얻으려고 대기하는 경우에 발생합니다.

FSLOG(FILESTREAM 로그) 잘림(백업 및 복원에서 사용)을 일시적으로 사용하지 않도록 설정합니다.

FSLOG 잘림의 한 주기를 실행합니다.
FSA_FORCE_OWN_XACT FILESTREAM 파일 I/O 작업이 연결된 트랜잭션에 바인딩해야 하지만 트랜잭션이 현재 다른 세션에서 소유하는 경우에 발생합니다.
FSAGENT FILESTREAM 파일 I/O 작업이 다른 파일 I/O 작업에 사용되는 FILESTREAM 에이전트 리소스를 기다리는 경우에 발생합니다.
FSTR_CONFIG_MUTEX 다른 FILESTREAM 기능 재구성이 완료될 때까지 대기하는 경우에 발생합니다.
FSTR_CONFIG_RWLOCK FILESTREAM 구성 매개 변수에 대한 액세스를 직렬화하기 위한 대기가 있을 때 발생합니다.
FT_METADATA_MUTEX 정보 제공 용도로만 문서화됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
FT_RESTART_CRAWL 일시적 오류에서 복구하기 위해 마지막으로 알려진 좋은 지점에서 전체 텍스트 크롤링을 다시 시작해야 하는 경우에 발생합니다. 대기하면 현재 해당 채우기에서 작업 중인 작업자 작업이 현재 단계를 완료하거나 종료할 수 있습니다.
FULLTEXT GATHERER 전체 텍스트 작업을 동기화하는 경우에 발생합니다.
후견인 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
HTTP_ENUMERATION 시작 시 HTTP 엔드포인트를 열거하여 HTTP를 시작할 때 발생합니다.
HTTP_START 연결이 HTTP가 초기화를 완료할 때까지 대기하는 경우에 발생합니다.
IMPPROV_IOWAIT SQL Server가 대량 로드 I/O가 완료되기를 기다리는 경우에 발생합니다.
INTERNAL_TESTING 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
IO_AUDIT_MUTEX 추적 이벤트 버퍼를 동기화하는 동안 발생합니다.
IO_COMPLETION I/O 작업이 완료되길 기다리는 동안 발생합니다. 이 대기 형식은 일반적으로 비데이터 페이지 I/O를 나타냅니다. 데이터 페이지 I/O 완료 대기는 PAGEIOLATCH_* 대기로 표시됩니다.
IO_QUEUE_LIMIT Azure SQL Database의 비동기 IO 큐에 보류 중인 IO가 너무 많은 경우에 발생합니다. 보류 중인 IO 수가 임계값 아래로 떨어질 때까지 다른 IO를 실행하려는 작업은 이 대기 유형에서 차단됩니다. 임계값은 데이터베이스에 할당된 DTU에 비례합니다.
IO_RETRY 리소스 부족으로 인해 디스크에 대한 읽기 또는 쓰기와 같은 I/O 작업이 실패하고 다시 시도될 때 발생합니다.
IOAFF_RANGE_QUEUE 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
KSOURCE_WAKEUP 서비스 제어 관리자의 요청을 기다리는 동안 서비스 제어 태스크에서 사용됩니다. 긴 대기가 예상되며 문제를 나타내지 않습니다.
KTM_ENLISTMENT 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
KTM_RECOVERY_MANAGER 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
KTM_RECOVERY_RESOLUTION 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
LATCH_DT DT(삭제) 래치를 대기할 때 발생합니다. 버퍼 래치 또는 트랜잭션 표시 래치를 포함하지 않습니다. 에서 LATCH_* 대기 목록을 사용할 수 있습니다 sys.dm_os_latch_stats. sys.dm_os_latch_stats 그룹 LATCH_NL, LATCH_SH, LATCH_UP, LATCH_EX 및 LATCH_DT 함께 대기합니다.
LATCH_EX EX(배타적) 래치를 대기할 때 발생합니다. 버퍼 래치 또는 트랜잭션 표시 래치를 포함하지 않습니다. 에서 LATCH_* 대기 목록을 사용할 수 있습니다 sys.dm_os_latch_stats. sys.dm_os_latch_stats 그룹 LATCH_NL, LATCH_SH, LATCH_UP, LATCH_EX 및 LATCH_DT 함께 대기합니다.
LATCH_KP KP(유지) 래치를 대기할 때 발생합니다. 버퍼 래치 또는 트랜잭션 표시 래치를 포함하지 않습니다. 에서 LATCH_* 대기 목록을 사용할 수 있습니다 sys.dm_os_latch_stats. sys.dm_os_latch_stats 그룹 LATCH_NL, LATCH_SH, LATCH_UP, LATCH_EX 및 LATCH_DT 함께 대기합니다.
LATCH_NL 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
LATCH_SH SH(공유) 래치를 대기할 때 발생합니다. 버퍼 래치 또는 트랜잭션 표시 래치를 포함하지 않습니다. 에서 LATCH_* 대기 목록을 사용할 수 있습니다 sys.dm_os_latch_stats. sys.dm_os_latch_stats 그룹 LATCH_NL, LATCH_SH, LATCH_UP, LATCH_EX 및 LATCH_DT 함께 대기합니다.
LATCH_UP UP(업데이트) 래치를 대기할 때 발생합니다. 버퍼 래치 또는 트랜잭션 표시 래치를 포함하지 않습니다. 에서 LATCH_* 대기 목록을 사용할 수 있습니다 sys.dm_os_latch_stats. sys.dm_os_latch_stats 그룹 LATCH_NL, LATCH_SH, LATCH_UP, LATCH_EX 및 LATCH_DT 함께 대기합니다.
LAZYWRITER_SLEEP 지연 작성기 작업이 일시 중단될 때 발생합니다. 이는 대기 중인 백그라운드 작업에서 소요된 시간의 측정값입니다. 사용자 중단을 찾는 경우 이 상태를 고려하지 마세요.
LCK_M_BU 태스크가 BU(대량 업데이트) 잠금을 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_IS 태스크가 내재된 공유(IS) 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_IU 태스크가 의도 업데이트(IU) 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_IX 태스크가 의도 배타(IX) 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RIn_NL 태스크가 현재 키 값에 대한 NULL 잠금 및 현재 키와 이전 키 사이의 삽입 범위 잠금을 획득하기 위해 대기하는 경우에 발생합니다. 키에 대한 NULL 잠금은 인스턴트 릴리스 잠금입니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RIn_S 태스크가 현재 키 값에 대한 공유 잠금을 획득하기 위해 대기 중이고 현재 키와 이전 키 사이에 범위 삽입 잠금이 있을 때 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RIn_U 작업이 현재 키 값에 대한 업데이트 잠금을 획득하고 현재 키와 이전 키 사이에 범위 삽입 잠금을 획득하기 위해 대기 중입니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RIn_X 태스크가 현재 키 값에 대한 배타적 잠금 및 현재 키와 이전 키 사이의 삽입 범위 잠금을 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RS_S 태스크가 현재 키 값의 공유 잠금 및 현재 키와 이전 키 간의 공유 범위 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RS_U 태스크가 현재 키 값의 업데이트 잠금 및 현재 키와 이전 키 간의 업데이트 범위 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RX_S 태스크가 현재 키 값에 대한 공유 잠금 및 현재 키와 이전 키 사이의 배타적 범위 잠금을 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RX_U 태스크가 현재 키 값의 업데이트 잠금 및 현재 키와 이전 키 간의 배타 범위 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_RX_X 태스크가 현재 키 값에 대한 배타적 잠금 및 현재 키와 이전 키 사이의 배타적 범위 잠금을 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_S 태스크가 공유 잠금을 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_SCH_M 태스크가 스키마 수정 잠금을 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_SCH_S 작업이 스키마 공유 잠금을 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_SIU 태스크가 의도 업데이트 공유 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_SIX 태스크가 의도 배타적 잠금을 사용하여 공유를 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_U 태스크가 업데이트 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_UIX 태스크가 의도 배타적 잠금을 사용하여 업데이트를 획득하기 위해 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LCK_M_X 태스크가 배타 잠금을 획득하려고 대기하는 경우에 발생합니다. 잠금 호환성 매트릭스는 sys.dm_tran_locks(Transact-SQL)를 참조하세요.
LOG_RATE_GOVERNOR DB가 로그에 쓰기 위해 할당량을 기다리고 있을 때 발생합니다.
LOGBUFFER 태스크가 로그 버퍼의 공간이 로그 레코드를 저장할 때까지 대기하는 경우에 발생합니다. 값이 계속 높게 나타나면 로그 디바이스가 서버에서 생성하는 로그의 양을 따라갈 수 없는 것일 수 있습니다.
LOGGENERATION 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
LOGMGR 태스크가 데이터베이스를 닫는 동안 로그를 종료하기 전에 미해결 로그 I/O가 완료되기를 기다리는 경우에 발생합니다.
LOGMGR_FLUSH 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
LOGMGR_QUEUE 로그 기록기 태스크가 작업 요청을 기다리는 동안 발생합니다.
LOGMGR_RESERVE_APPEND 태스크가 로그 잘림으로 인해 로그 공간이 확보되어 작업이 새 로그 레코드를 쓸 수 있는지 확인하려고 대기하는 경우에 발생합니다. 이 대기 시간을 줄이기 위해 영향을 받는 데이터베이스에 대한 로그 파일의 크기를 늘리는 것이 좋습니다.
LOWFAIL_MEMMGR_QUEUE 메모리를 사용할 수 있을 때까지 기다리는 동안 발생합니다.
MSQL_DQ 태스크가 분산 쿼리 작업이 완료되기를 기다리는 경우에 발생합니다. MARS(다중 활성 결과 집합) 애플리케이션 교착 상태를 검색하는 데 사용됩니다. 분산 쿼리 호출이 완료되면 대기가 종료됩니다.
MSQL_XACT_MGR_MUTEX 태스크가 세션 수준 트랜잭션 작업을 수행하기 위해 세션 트랜잭션 관리자의 소유권을 얻기 위해 대기하는 경우에 발생합니다.
MSQL_XACT_MUTEX 트랜잭션 사용량을 동기화하는 동안 발생합니다. 요청에서 트랜잭션을 사용하려면 먼저 뮤텍스를 획득해야 합니다.
MSQL_XP 작업이 확장 저장 프로시저가 종료될 때까지 대기하는 경우에 발생합니다. SQL Server는 이 대기 상태를 사용하여 잠재적인 MARS 애플리케이션 교착 상태를 검색합니다. 대기는 확장 저장 프로시저 호출이 끝날 때 중지됩니다.
MSSEARCH 전체 텍스트 검색 호출 중에 발생합니다. 이 대기는 전체 텍스트 작업이 완료되면 종료됩니다. 경합이 아니라 전체 텍스트 작업의 기간을 나타냅니다.
NET_WAITFOR_PACKET 네트워크를 읽는 동안 연결이 네트워크 패킷을 기다리는 동안 발생합니다.
OLEDB SQL Server가 SQL Server Native Client OLE DB 공급자를 호출할 때 발생합니다. 이 대기 유형은 동기화에 사용되지 않습니다. 대신 OLE DB Provider에 대한 호출 기간을 나타냅니다.
ONDEMAND_TASK_QUEUE 백그라운드 작업이 우선 순위가 높은 시스템 작업 요청을 기다리는 동안 발생합니다. 대기 시간이 길면 처리할 우선 순위가 높은 요청이 없었으며 문제가 발생하지 않아야 합니다.
PAGEIOLATCH_DT 태스크가 I/O 요청에 있는 버퍼를 래치에서 기다리는 경우에 발생합니다. 래치 요청이 삭제 모드에 있습니다. 대기 수가 많으면 디스크 하위 시스템에 문제가 있을 수 있습니다.
PAGEIOLATCH_EX 태스크가 I/O 요청에 있는 버퍼를 래치에서 기다리는 경우에 발생합니다. 래치 요청이 배타 모드에 있습니다. 대기 수가 많으면 디스크 하위 시스템에 문제가 있을 수 있습니다.
PAGEIOLATCH_KP 태스크가 I/O 요청에 있는 버퍼를 래치에서 기다리는 경우에 발생합니다. 래치 요청이 유지 모드에 있습니다. 대기 수가 많으면 디스크 하위 시스템에 문제가 있을 수 있습니다.
PAGEIOLATCH_NL 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
PAGEIOLATCH_SH 태스크가 I/O 요청에 있는 버퍼를 래치에서 기다리는 경우에 발생합니다. 래치 요청이 공유 모드에 있습니다. 대기 수가 많으면 디스크 하위 시스템에 문제가 있을 수 있습니다.
PAGEIOLATCH_UP 태스크가 I/O 요청에 있는 버퍼를 래치에서 기다리는 경우에 발생합니다. 래치 요청이 업데이트 모드에 있습니다. 대기 수가 많으면 디스크 하위 시스템에 문제가 있을 수 있습니다.
PAGELATCH_DT 태스크가 I/O 요청에 없는 버퍼에 대한 래치를 대기할 때 발생합니다. 래치 요청이 삭제 모드에 있습니다.
PAGELATCH_EX 태스크가 I/O 요청에 없는 버퍼에 대한 래치를 대기할 때 발생합니다. 래치 요청이 배타 모드에 있습니다.
PAGELATCH_KP 태스크가 I/O 요청에 없는 버퍼에 대한 래치를 대기할 때 발생합니다. 래치 요청이 유지 모드에 있습니다.
PAGELATCH_NL 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
PAGELATCH_SH 태스크가 I/O 요청에 없는 버퍼에 대한 래치를 대기할 때 발생합니다. 래치 요청이 공유 모드에 있습니다.
PAGELATCH_UP 태스크가 I/O 요청에 없는 버퍼에 대한 래치를 대기할 때 발생합니다. 래치 요청이 업데이트 모드에 있습니다.
PARALLEL_BACKUP_QUEUE RESTORE HEADERONLY, RESTORE FILELISTONLY 또는 RESTORE LABELONLY에서 생성된 출력을 직렬화할 때 발생합니다.
PREEMPTIVE_ABR 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
PREEMPTIVE_AUDIT_ACCESS_EVENTLOG SQLOS(SQL Server 운영 체제) 스케줄러가 선점 모드로 전환하여 Windows 이벤트 로그에 감사 이벤트를 쓸 때 발생합니다.
PREEMPTIVE_AUDIT_ACCESS_SECLOG SQLOS 스케줄러가 선점 모드로 전환하여 감사 이벤트를 Windows 보안 로그에 쓸 때 발생합니다.
PREEMPTIVE_CLOSEBACKUPMEDIA SQLOS 스케줄러가 선점 모드로 전환하여 백업 미디어를 닫을 때 발생합니다.
PREEMPTIVE_CLOSEBACKUPTAPE SQLOS 스케줄러가 선점 모드로 전환하여 테이프 백업 디바이스를 닫을 때 발생합니다.
PREEMPTIVE_CLOSEBACKUPVDIDEVICE SQLOS 스케줄러가 선점 모드로 전환하여 가상 백업 디바이스를 닫을 때 발생합니다.
PREEMPTIVE_CLUSAPI_CLUSTERRESOURCECONTROL SQLOS 스케줄러가 선점 모드로 전환하여 Windows 장애 조치(failover) 클러스터 작업을 수행할 때 발생합니다.
PREEMPTIVE_COM_COCREATEINSTANCE SQLOS 스케줄러가 선점 모드로 전환하여 COM 개체를 만들 때 발생합니다.
PREEMPTIVE_HADR_LEASE_MECHANISM CSS 진단을 위한 Always On 가용성 그룹 임대 관리자 예약
PREEMPTIVE_SOSTESTING 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
PREEMPTIVE_STRESSDRIVER 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
PREEMPTIVE_TESTING 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
PREEMPTIVE_XETESTING 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
PRINT_ROLLBACK_PROGRESS ALTER DATABASE termination 절을 사용하여 전환된 데이터베이스에서 사용자 프로세스가 끝나기를 기다리는 데 사용됩니다. 자세한 내용은 ALTER DATABASE(Transact-SQL)를 참조하세요.
PWAIT_HADR_CHANGE_NOTIFIER_TERMINATION_SYNC 백그라운드 작업이 (폴링을 통해) Windows Server 장애 조치(failover) 클러스터링 알림을 수신하는 백그라운드 작업의 종료를 기다리는 경우에 발생합니다. 내부용으로만 사용됩니다.
PWAIT_HADR_CLUSTER_INTEGRATION 추가, 바꾸기 및/또는 제거 작업이 Always On 내부 목록(예: 네트워크, 네트워크 주소 또는 가용성 그룹 수신기 목록)에서 쓰기 잠금을 잡기 위해 대기 중입니다. 내부용으로만 사용됩니다.
PWAIT_HADR_OFFLINE_COMPLETED Always On 놓기 가용성 그룹 작업은 Windows Server 장애 조치(failover) 클러스터링 개체를 삭제하기 전에 대상 가용성 그룹이 오프라인 상태가 되기를 기다리고 있습니다.
PWAIT_HADR_ONLINE_COMPLETED Always On에서 가용성 그룹 만들기 또는 장애 조치(failover) 작업이 대상 가용성 그룹이 온라인 상태가 될 때까지 기다리고 있습니다.
PWAIT_HADR_POST_ONLINE_COMPLETED Always On 놓기 가용성 그룹 작업이 이전 명령의 일부로 예약된 백그라운드 작업의 종료를 기다리고 있습니다. 예를 들어 가용성 데이터베이스를 주 역할로 전환하는 백그라운드 작업이 있을 수 있습니다. 경합 상태를 방지하기 위해 DROP AVAILABILITY GROUP DDL이 이 백그라운드 태스크가 종료될 때까지 기다려야 합니다.
PWAIT_HADR_WORKITEM_COMPLETED 비동기 작업 작업이 완료되기를 기다리는 스레드의 내부 대기입니다. 이는 예상된 대기이며 CSS 사용을 위한 것입니다.
PWAIT_MD_LOGIN_STATS 로그인 통계의 메타데이터에서 내부 동기화 중에 발생합니다.
PWAIT_MD_RELATION_CACHE 테이블 또는 인덱스의 메타데이터에서 내부 동기화 중에 발생합니다.
PWAIT_MD_SERVER_CACHE 연결된 서버에서 메타데이터의 내부 동기화 중에 발생합니다.
PWAIT_MD_UPGRADE_CONFIG 서버 전체 구성을 업그레이드할 때 내부 동기화 중에 발생합니다.
PWAIT_METADATA_LAZYCACHE_RWLOCk 메타데이터 캐시에서 내부 동기화 중에 테이블의 반복 인덱스 또는 통계와 함께 발생합니다.
QPJOB_KILL 업데이트가 실행되기 시작할 때 KILL 호출에 의해 비동기 자동 통계 업데이트가 취소되었음을 나타냅니다. 종료하는 스레드는 일시 중지 상태로, KILL 명령을 수신하기 시작할 때까지 대기합니다. 좋은 값은 1초 미만입니다.
QPJOB_WAITFOR_ABORT 실행 중 KILL 호출에 의해 비동기 자동 통계 업데이트가 취소되었음을 나타냅니다. 이제 업데이트가 완료되었지만 종료 스레드 메시지 조정이 완료될 때까지 일시 중단됩니다. 이것은 평범하지만 드문 상태이며 매우 짧아야합니다. 좋은 값은 1초 미만입니다.
QRY_MEM_GRANT_INFO_MUTEX 쿼리 실행 메모리 관리가 정적 권한 부여 정보 목록에 대한 액세스를 제어하려고 할 때 발생합니다. 이 상태는 현재 부여 및 대기 중인 메모리 요청에 대한 정보를 나열합니다. 이 상태는 간단한 액세스 제어 상태입니다. 이 상태에 대해 오래 기다려서는 안됩니다. 이 뮤텍스가 릴리스되지 않으면 모든 새 메모리 사용 쿼리가 응답을 중지합니다.
QUERY_ERRHDL_SERVICE_DONE 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
QUERY_EXECUTION_INDEX_SORT_EVENT_OPEN 오프라인 인덱스 빌드 생성이 병렬로 실행되고 정렬되는 여러 작업자 스레드가 정렬 파일에 대한 액세스를 동기화하는 특정 경우에 발생합니다.
QUERY_NOTIFICATION_MGR_MUTEX 쿼리 알림 관리자에서 가비지 수집 큐를 동기화하는 동안 발생합니다.
QUERY_NOTIFICATION_SUBSCRIPTION_MUTEX 쿼리 알림의 트랜잭션에 대한 상태 동기화 중에 발생합니다.
QUERY_NOTIFICATION_TABLE_MGR_MUTEX 쿼리 알림 관리자 내에서 내부 동기화 중에 발생합니다.
QUERY_NOTIFICATION_UNITTEST_MUTEX 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
QUERY_OPTIMIZER_PRINT_MUTEX 쿼리 최적화 프로그램 진단 출력 프로덕션을 동기화하는 동안 발생합니다. 이 대기 유형은 Microsoft 제품 지원의 지시에 따라 진단 설정을 사용하도록 설정한 경우에만 발생합니다.
QUERY_TRACEOUT 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
QUERY_WAIT_ERRHDL_SERVICE 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
RECOVER_CHANGEDB 웜 대기 데이터베이스에서 데이터베이스 상태를 동기화하는 동안 발생합니다.
REPL_CACHE_ACCESS 복제 아티클 캐시에서 동기화하는 동안 발생합니다. 이러한 대기 중에 복제 로그 판독기 중단 및 게시된 테이블의 DDL(데이터 정의 언어) 문이 차단됩니다.
REPL_SCHEMA_ACCESS 복제 스키마 버전 정보 동기화 중에 발생합니다. 이 상태는 복제된 개체에서 DDL 문이 실행되고 로그 판독기에서 DDL 발생에 따라 버전이 지정된 스키마를 빌드하거나 사용할 때 존재합니다.
REPLICA_WRITES 태스크가 데이터베이스 스냅샷 또는 DBCC 복제본에 대한 페이지 쓰기 완료를 기다리는 동안 발생합니다.
REQUEST_DISPENSER_PAUSE 작업에서 모든 미해결 I/O가 완료되기를 기다리는 경우 스냅샷 백업을 위해 파일에 대한 I/O를 고정할 수 있도록 발생합니다.
REQUEST_FOR_DEADLOCK_SEARCH 교착 상태 모니터가 다음 교착 상태 검색을 시작하기 위해 기다리는 동안 발생합니다. 이 대기는 교착 상태 감지 사이에 발생하며 이 리소스에 대한 총 대기 시간이 길어도 문제가 있는 것은 아닙니다.
RESMGR_THROTTLED 새 요청이 들어오고 GROUP_MAX_REQUESTS 설정에 따라 제한될 때 발생합니다.
RESOURCE_QUEUE 다양한 내부 리소스 큐 동기화 중에 발생합니다.
RESOURCE_SEMAPHORE 다른 동시 쿼리로 인해 쿼리 메모리 요청을 즉시 허용할 수 없는 경우에 발생합니다. 높은 대기 및 대기 시간은 과도한 동시 쿼리 수 또는 과도한 메모리 요청 양을 나타낼 수 있습니다.
RESOURCE_SEMAPHORE_MUTEX 쿼리가 스레드 예약 요청이 수행될 때까지 대기하는 동안 발생합니다. 쿼리 컴파일 및 메모리 부여 요청을 동기화할 때도 발생합니다.
RESOURCE_SEMAPHORE_QUERY_COMPILE 동시 쿼리 컴파일 수가 제한 제한에 도달하면 발생합니다. 대기 수가 많고 대기 시간이 길면 컴파일, 다시 컴파일 또는 캐싱할 수 없는 계획 수가 과도하게 많은 것입니다.
RESOURCE_SEMAPHORE_SMALL_QUERY 다른 동시 쿼리로 인해 작은 쿼리의 메모리 요청을 즉시 부여할 수 없는 경우에 발생합니다. 서버가 요청된 메모리를 몇 초 내에 부여하지 못하는 경우 주 쿼리 메모리 풀로 요청을 전송하기 때문에 대기 시간은 몇 초를 초과하지 않아야 합니다. 대기 시간이 많으면 쿼리 대기로 인해 주 메모리 풀이 차단되는 동안 동시 작은 쿼리 수가 너무 많을 수 있습니다.
SE_REPL_CATCHUP_THROTTLE 트랜잭션이 데이터베이스 보조 데이터베이스 중 하나가 진행되도록 대기하는 경우에 발생합니다.
SE_REPL_COMMIT_ACK 트랜잭션이 보조 복제본에서 쿼럼 커밋 승인을 기다리는 경우에 발생합니다.
SE_REPL_COMMIT_TURN 트랜잭션이 쿼럼 커밋 승인을 받은 후 커밋을 대기할 때 발생합니다.
SE_REPL_ROLLBACK_ACK 트랜잭션이 보조 복제본에서 쿼럼 롤백 승인을 기다리는 경우에 발생합니다.
SE_REPL_SLOW_SECONDARY_THROTTLE 스레드가 데이터베이스 보조 복제본 중 하나를 대기할 때 발생합니다.
SEC_DROP_TEMP_KEY 다시 시도하기 전에 임시 보안 키를 삭제하는 데 실패한 후에 발생합니다.
SECURITY_MUTEX EKM(Extensible Key Management) 암호화 공급자의 전역 목록과 세션 범위가 지정된 EKM 세션 목록에 대한 액세스를 제어하는 뮤텍스에 대한 대기가 있을 때 발생합니다.
SEQUENTIAL_GUID 새 순차 GUID를 가져오는 동안 발생합니다.
SERVER_IDLE_CHECK 리소스 모니터가 SQL Server 인스턴스를 유휴 상태로 선언하거나 절전 모드 해제를 시도할 때 SQL Server 인스턴스 유휴 상태를 동기화하는 동안 발생합니다.
SHUTDOWN 종료 문이 활성 연결이 종료되기를 기다리는 동안 발생합니다.
SLEEP_BPOOL_FLUSH 검사점이 디스크 하위 시스템의 홍수를 방지하기 위해 새 I/O 발급을 제한할 때 발생합니다.
SLEEP_DBSTARTUP 모든 데이터베이스가 복구되도록 기다리는 동안 데이터베이스를 시작하는 동안 발생합니다.
SLEEP_DCOMSTARTUP DCOM 초기화가 완료될 때까지 기다리는 동안 SQL Server 인스턴스를 시작하는 동안 최대 한 번 발생합니다.
SLEEP_MSDBSTARTUP SQL Trace가 msdb 데이터베이스의 시작이 완료될 때까지 대기할 때 발생합니다.
SLEEP_SYSTEMTASK tempdb가 시작이 완료될 때까지 기다리는 동안 백그라운드 작업이 시작되는 동안 발생합니다.
SLEEP_TASK 제네릭 이벤트가 발생할 때까지 기다리는 동안 태스크가 절전 모드로 설정되면 발생합니다.
SLEEP_TEMPDBSTARTUP 태스크가 tempdb 시작이 완료될 때까지 대기하는 동안 발생합니다.
SNI_CRITICAL_SECTION SQL Server 네트워킹 구성 요소 내에서 내부 동기화 중에 발생합니다.
SNI_HTTP_WAITFOR_0_DISCON SQL Server를 종료하는 동안 미해결 HTTP 연결이 종료되도록 기다리는 동안 발생합니다.
SNI_LISTENER_ACCESS NUMA(비균일 메모리 액세스) 노드가 상태 변경을 업데이트할 때까지 기다리는 동안 발생합니다. 상태 변경에 대한 액세스가 직렬화됩니다.
SNI_TASK_COMPLETION NUMA 노드 상태 변경 동안 모든 태스크가 완료될 때까지 대기하는 중에 발생합니다.
SOAP_READ HTTP 네트워크 읽기가 완료되길 기다리는 동안 발생합니다.
SOAP_WRITE HTTP 네트워크 쓰기가 완료되길 기다리는 동안 발생합니다.
SOS_CALLBACK_REMOVAL 콜백을 제거하기 위해 콜백 목록에서 동기화를 수행하는 동안 발생합니다. 서버 초기화가 완료된 후에는 이 카운터가 변경되지 않을 것으로 예상됩니다.
SOS_DISPATCHER_MUTEX 디스패처 풀의 내부 동기화 중에 발생합니다. 여기에는 풀이 조정되는 시기가 포함됩니다.
SOS_LOCALALLOCATORLIST SQL Server 메모리 관리자에서 내부 동기화 중에 발생합니다.
SOS_MEMORY_USAGE_ADJUSTMENT 풀 간에 메모리 사용량을 조정할 때 발생합니다.
SOS_OBJECT_STORE_DESTROY_MUTEX 풀에서 개체를 삭제할 때 메모리 풀에서 내부 동기화 중에 발생합니다.
SOS_PROCESS_AFFINITY_MUTEX 프로세스 선호도 설정에 대한 액세스를 동기화하는 동안 발생합니다.
SOS_RESERVEDMEMBLOCKLIST SQL Server 메모리 관리자에서 내부 동기화 중에 발생합니다.
SOS_SCHEDULER_YIELD 태스크가 다른 태스크가 실행할 스케줄러를 자발적으로 생성할 때 발생합니다. 이 대기 중에 태스크는 양자가 갱신되기를 기다리고 있습니다.
SOS_SMALL_PAGE_ALLOC 일부 메모리 개체에서 관리하는 메모리를 할당하고 해제하는 동안 발생합니다.
SOS_STACKSTORE_INIT_MUTEX 내부 저장소 초기화 동기화 중에 발생합니다.
SOS_SYNC_TASK_ENQUEUE_EVENT 작업이 동기식으로 시작될 때 발생합니다. SQL Server의 대부분의 작업은 작업 요청이 작업 큐에 배치된 직후에 컨트롤이 시작으로 반환되는 비동기 방식으로 시작됩니다.
SOS_VIRTUALMEMORY_LOW 메모리 할당이 리소스 관리자가 가상 메모리를 확보할 때까지 대기할 때 발생합니다.
SOSHOST_EVENT CLR과 같은 호스트된 구성 요소가 SQL Server 이벤트 동기화 개체에서 대기할 때 발생합니다.
SOSHOST_INTERNAL CLR과 같은 호스트된 구성 요소에서 사용하는 메모리 관리자 콜백을 동기화하는 동안 발생합니다.
SOSHOST_MUTEX CLR과 같은 호스트된 구성 요소가 SQL Server 뮤텍스 동기화 개체에서 대기할 때 발생합니다.
SOSHOST_RWLOCK CLR과 같은 호스트된 구성 요소가 SQL Server 판독기-기록기 동기화 개체를 대기할 때 발생합니다.
SOSHOST_SEMAPHORE CLR과 같은 호스트된 구성 요소가 SQL Server 세마포 동기화 개체에서 대기할 때 발생합니다.
SOSHOST_SLEEP 일반 이벤트가 발생할 때까지 대기하는 동안 호스팅된 태스크가 중지되는 경우에 발생합니다. 호스트된 작업은 CLR과 같은 호스트된 구성 요소에서 사용됩니다.
SOSHOST_TRACELOCK 추적 스트림에 대한 액세스를 동기화하는 동안 발생합니다.
SOSHOST_WAITFORDONE CLR과 같은 호스트된 구성 요소가 작업이 완료되기를 기다리는 경우에 발생합니다.
SQLCLR_APPDOMAIN CLR이 애플리케이션 도메인이 시작이 완료되기를 기다리는 동안 발생합니다.
SQLCLR_ASSEMBLY appdomain에서 로드된 어셈블리 목록에 대한 액세스를 기다리는 동안 발생합니다.
SQLCLR_DEADLOCK_DETECTION CLR이 교착 상태 검색이 완료되기를 기다리는 동안 발생합니다.
SQLCLR_QUANTUM_PUNISHMENT CLR 태스크가 실행 양자를 초과하여 제한될 때 발생합니다. 이러한 조절은 리소스를 많이 사용하는 이 태스크가 다른 작업에 미치는 영향을 줄이기 위해 수행됩니다.
SQLSORT_NORMMUTEX 내부 정렬 구조를 초기화하는 동안 내부 동기화 중에 발생합니다.
SQLSORT_SORTMUTEX 내부 정렬 구조를 초기화하는 동안 내부 동기화 중에 발생합니다.
SQLTRACE_BUFFER_FLUSH 태스크가 백그라운드 작업이 추적 버퍼를 디스크에 4초마다 플러시할 때까지 대기하는 경우에 발생합니다.
SQLTRACE_LOCK 파일 추적 중에 추적 버퍼를 동기화하는 동안 발생합니다.
SQLTRACE_SHUTDOWN 추적 종료가 미해결 추적 이벤트가 완료되기를 기다리는 동안 발생합니다.
SQLTRACE_WAIT_ENTRIES SQL 추적 이벤트 큐가 패킷이 큐에 도착할 때까지 기다리는 동안 발생합니다.
SRVPROC_SHUTDOWN 종료 프로세스가 내부 리소스가 완전히 종료될 때까지 기다리는 동안 발생합니다.
TEMPOBJ 임시 개체 삭제가 동기화되는 경우에 발생합니다. 이 대기는 드물며 태스크가 임시 테이블에 대한 단독 액세스를 요청한 경우에만 발생합니다.
THREADPOOL 작업에서 작업자가 실행될 때까지 대기하는 경우에 발생합니다. 이는 최대 작업자 설정이 너무 낮거나 해당 일괄 처리 실행이 비정상적으로 오래 수행되어 다른 일괄 처리에 사용할 수 있는 작업자 수가 감소한 것입니다.
TIMEPRIV_TIMEPERIOD 확장 이벤트 타이머의 내부 동기화 중에 발생합니다.
TRACEWRITE SQL 추적 행 집합 추적 공급자가 처리할 이벤트가 있는 무료 버퍼 또는 버퍼를 대기할 때 발생합니다.
TRAN_MARKLATCH_DT 트랜잭션 표시 래치에서 삭제 모드 래치를 대기할 때 발생합니다. 트랜잭션 표시 래치는 표시된 트랜잭션을 사용하여 커밋을 동기화하는 데 사용됩니다.
TRAN_MARKLATCH_EX 표시된 트랜잭션에서 배타적 모드 래치를 기다리는 경우에 발생합니다. 트랜잭션 표시 래치는 표시된 트랜잭션을 사용하여 커밋을 동기화하는 데 사용됩니다.
TRAN_MARKLATCH_KP 표시된 트랜잭션에서 유지 모드 래치를 대기할 때 발생합니다. 트랜잭션 표시 래치는 표시된 트랜잭션을 사용하여 커밋을 동기화하는 데 사용됩니다.
TRAN_MARKLATCH_NL 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
TRAN_MARKLATCH_SH 표시된 트랜잭션에 대한 공유 모드 래치를 대기하는 경우에 발생합니다. 트랜잭션 표시 래치는 표시된 트랜잭션을 사용하여 커밋을 동기화하는 데 사용됩니다.
TRAN_MARKLATCH_UP 표시된 트랜잭션에서 업데이트 모드 래치를 대기할 때 발생합니다. 트랜잭션 표시 래치는 표시된 트랜잭션을 사용하여 커밋을 동기화하는 데 사용됩니다.
TRANSACTION_MUTEX 트랜잭션에 대한 액세스를 여러 일괄 처리로 동기화하는 동안 발생합니다.
THROTTLE_LOG_RATE_LOG_STORAGE 기본 스토리지의 성능 기능으로 인해 DB 로그에 쓰기가 제한될 때 발생합니다.
UTIL_PAGE_ALLOC 트랜잭션 로그 검사가 메모리 압력 중에 메모리를 사용할 수 있을 때까지 대기할 때 발생합니다.
VIA_ACCEPT 시작하는 동안 VIA(Virtual Interface Adapter) 공급자 연결이 완료된 경우에 발생합니다.
VIEW_DEFINITION_MUTEX 캐시된 뷰 정의에 대한 액세스에서 동기화하는 동안 발생합니다.
WAIT_FOR_RESULTS 쿼리 알림이 트리거될 때까지 대기할 때 발생합니다.
WAITFOR WAITFOR Transact-SQL 문의 결과로 발생합니다. 대기 기간은 문에 대한 매개 변수에 의해 결정됩니다. 사용자가 시작한 대기입니다.
WAITFOR_TASKSHUTDOWN 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
WAITSTAT_MUTEX 채우는 sys.dm_os_wait_stats데 사용되는 통계 컬렉션에 대한 액세스를 동기화하는 동안 발생합니다.
WCC 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
WORKTBL_DROP 다시 시도하기 전에 일시 중지하는 동안 실패한 작업 가능 삭제 후에 발생합니다.
WRITE_COMPLETION 쓰기 작업이 진행 중일 때 발생합니다.
WRITELOG 로그 플러시가 완료되길 기다리는 동안 발생합니다. 로그 플러시를 발생시키는 일반적인 작업은 검사점 및 트랜잭션 커밋입니다.
XACT_OWN_TRANSACTION 트랜잭션의 소유권을 획득하기 위해 대기하는 동안 발생합니다.
XACT_RECLAIM_SESSION 세션의 현재 소유자가 세션의 소유권을 해제할 때까지 기다리는 동안 발생합니다.
XACTLOCKINFO 트랜잭션에 대한 잠금 목록에 대한 액세스를 동기화하는 동안 발생합니다. 트랜잭션 자체 외에도 페이지 분할 중에 교착 상태 검색 및 잠금 마이그레이션과 같은 작업을 통해 잠금 목록에 액세스합니다.
XACTWORKSPACE_MUTEX 트랜잭션에서 탈퇴를 동기화하는 동안 발생하며 트랜잭션의 등록 멤버 간에 데이터베이스 잠금의 수가 발생합니다.
XE_BUFFERMGR_ALLPROCESSED_EVENT 확장 이벤트 세션 버퍼가 대상으로 플러시될 때 발생합니다. 이 대기는 백그라운드 스레드에서 발생합니다.
XE_BUFFERMGR_FREEBUF_EVENT 다음 조건 중 하나가 true인 경우 발생합니다.

확장 이벤트 세션은 이벤트 손실 없이 구성되며 세션의 모든 버퍼는 현재 가득 찼습니다. 확장 이벤트 세션의 버퍼가 너무 작거나 분할되어야 함을 나타낼 수 있습니다.

감사 지연이 발생하는 경우. 이는 감사를 기록하는 드라이브에 디스크 병목 현상이 있음을 의미할 수 있습니다.
XE_DISPATCHER_CONFIG_SESSION_LIST 비동기 대상을 사용하는 확장 이벤트 세션이 시작 또는 중지될 때 발생합니다. 이 대기는 다음 중 하나를 나타냅니다.

확장 이벤트 세션이 백그라운드 스레드 풀에 등록됩니다.

백그라운드 스레드 풀은 현재 로드에 따라 필요한 스레드 수를 계산합니다.
XE_DISPATCHER_JOIN 확장 이벤트 세션에 사용되는 백그라운드 스레드가 종료되는 경우에 발생합니다.
XE_DISPATCHER_WAIT 확장 이벤트 세션에 사용되는 백그라운드 스레드가 이벤트 버퍼 처리를 기다리는 경우 발생합니다.
XE_MODULEMGR_SYNC 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
XE_OLS_LOCK 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
XE_PACKAGE_LOCK_BACKOFF 정보를 제공하기 위해서만 확인됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
FT_COMPROWSET_RWLOCK 전체 텍스트가 조각 메타데이터 작업을 기다리고 있습니다. 정보 제공 용도로만 문서화됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
FT_IFTS_RWLOCK 전체 텍스트가 내부 동기화를 기다리고 있습니다. 정보 제공 용도로만 문서화됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
FT_IFTS_SCHEDULER_IDLE_WAIT 전체 텍스트 스케줄러 중지 대기 유형입니다. 스케줄러가 유휴 상태입니다.
FT_IFTSHC_MUTEX 전체 텍스트가 fdhost 컨트롤 작업을 기다리고 있습니다. 정보 제공 용도로만 문서화됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
FT_IFTSISM_MUTEX 전체 텍스트가 통신 작업을 기다리고 있습니다. 정보 제공 용도로만 문서화됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.
FT_MASTER_MERGE 마스터 병합 작업에서 전체 텍스트가 대기 중입니다. 정보 제공 용도로만 문서화됩니다. 지원 안 됨 향후 호환성은 보장되지 않습니다.

참고 항목

sys.dm_os_sys_info(Transact-SQL)
sys.dm_tran_locks (Transact-SQL)
sys.dm_os_waiting_tasks(Transact-SQL)