성능분석 1탄 – 실행 요청을 기다리는 작업 확인 및 분석

  • 다른 세션에 의한 블록킹 확인

     

  • Version : SQL Server 2005, 2008, 2008R2, 2012

 

SQL Server에서 요청한 작업의 결과가 느리게 반환될 때가 있다. 이는 요청 된 작업의 처리량이 많아서 처리 속도가 오래 걸릴 수도 있지만 다른 작업에 의해 대기가 발생하여 작업이 기다리게 되는 상황이 발생 할 수도 있다.

 

현재 실행을 위해 대기하는 요청을 확인 하기 위해서는 DMV 함수 sys.dm_exec_requests 를 사용할 수 있다.

Sys.dm_exec_requests 결과에서 wait_time 및 wait_type 열을 확인 하여 현재 어떤 작업이 대기 하고 있는지 또는 실행되고 있는지 확인 할 수 있다.

 

Select

    session_id,

    status,

    command,

    blocking_session_id,

    wait_type,

    wait_time,

    last_wait_type,

    wait_resource

from sys.dm_exec_requests

where session_id >= 50 and session_id <> @@spid;

 

 

  • 세션53의 상태는 56번 세션에 의해 SELECT 작업이 대기하고 있다.
  • 세션 54의 상태는 세션 55에 의해서 INSERT 작업이 대기 하고 있다.
  • 세션 55의 상태는 INSERT 작업이 진행 중이며 이전대기 상태는 PAGELATCH_SH 이다.
  • 세선 56의 상태는 INSERT 작업이 대기 중이며 WRITELOG (트랜잭션 커밋)로 데이터베이스 로그 플러시를 기다리고 있다.
  • 세션 57의 상태는 INSERT 작업이 대기 중이며 WRITELOG로 데이터베이스 로그 플러시를 기다리고 있다.

 

세션 54의 현재 상태는 실행 중이지만 실제로는 대기 하고 있다. 하지만 대기 상태가 래치이므로 매우 짧을 것으로 예상된다.

Blocking_session_id의 정보를 보면 어떤 다른 요청에 의해서 현재 대기하고 있는지 알려준다. 세션 53의 SELECT의 경우 행을 읽으려고 KEY 잠금 리소스에 대한 56 세션의 작업을 기다리고 있다. 세션 56의 INSERT 작업이 커밋 될 때까지 세션 53의 SELECT가 되지 않는다.

 

세션 54는 세션 55의 INSERT 작업으로 해당 페이지를 수정하고 페이지의 데이터를 판독할 수 없는 불안정환 상태로 페이지 래치에 대한 세션을 기다리고 있다.

 

세션 56,57의 경우는 다른 세션으로 인한 차단은 없지만 대기 하고 있다. 이 대기 작업은 트랜잭션이 디스크 기록에 대한 커밋을 확인 하는 것으로 로그 플러시를 기다리고 있다. 디스크에 로그가 모두 기록되기 전까지 대기가 발생 한다.

 

 

[참고자료]

http://rusanu.com/2014/02/24/how-to-analyse-sql-server-performance/#wait_info_current

 




강성욱 / jevida@naver.com
Microsoft SQL Server MVP
Blog : http://sqlmvp.kr
Facebook : http://facebook.com/sqlmvp

No. Subject Author Date Views
Notice SQL강좌: 챗GPT와 함께 배우는 SQL Server 무료 강좌 목차와 소개 (2023년 9월 업데이트) 코난(김대우) 2023.08.18 34981
Notice Python 무료 강좌 - 기초, 중급, 머신러닝(2023년 6월 업데이트) 코난(김대우) 2021.01.01 17248
1934 확장이벤트를 사용하여 데드락 정보 확인 jevida(강성욱) 2016.10.15 1662
1933 확장 이벤트를 사용한 CPU 고부하 쿼리 추적 [1] jevida(강성욱) 2016.10.15 2220
1932 데이터에 대한 이해와 spill in tempdb jevida(강성욱) 2016.10.13 1820
1931 로그 파일이 많으면 왜 안 좋은가 jevida(강성욱) 2016.10.13 2119
1930 트랜잭션 백업 실패와 전체 백업 성공 그리고 대처 방안 jevida(강성욱) 2016.10.13 1618
1929 Fast recovery 와 로그 잠금 jevida(강성욱) 2016.10.13 2072
1928 고스트 클린업 jevida(강성욱) 2016.10.13 2348
1927 페이지 분할이 발생 하였을 때 롤백을 하면 어떻게 될까? jevida(강성욱) 2016.10.13 1711
1926 DBCC WRITEPAGE - DBCC 명령을 사용한 데이터 파괴하기 jevida(강성욱) 2016.10.13 1697
1925 SQL Server Backup Error 3023 jevida(강성욱) 2016.10.13 2446
1924 Delete 작업과 페이지 offset 변화 jevida(강성욱) 2016.10.13 1546
1923 트랜잭션 로그 및 LSN을 이용한 삭제된 데이터 복구 jevida(강성욱) 2016.10.13 5826
1922 PFX 형식의 인증서를 SQL Server에서 사용하기 jevida(강성욱) 2016.10.13 1212
1921 SQL Server NUMA 메모리 노드와 Operating System 접근 jevida(강성욱) 2016.10.13 1369
1920 SQL Server 에러 핸들링 비용 비교 jevida(강성욱) 2016.10.13 1357
1919 압축 백업 시 Checksum 옵션으로 손상 확인하기 jevida(강성욱) 2016.10.13 1751
1918 SQL Server 2012 Memory Manager 구성 jevida(강성욱) 2016.10.13 1303
1917 SQL Server Memory Manager 변화 jevida(강성욱) 2016.10.13 1560
1916 Ring_Buffer_Resource_Monitor jevida(강성욱) 2016.10.13 1093
1915 SQL Server 프로파일러 템플릿 만들기 jevida(강성욱) 2016.10.13 1424





XE Login