DataBase/SQL Server

SP_LOCK, KILL - 락 확인 및 강제종료

탑~! 2021. 1. 5. 15:36

● SP_LOCK - 락 걸린 쿼리 확인 및 강제종료

MS-SQL에서 SELECT 실행 시 조회 결과가 나오지 않거나 타임아웃에 걸려 커넥션이 끊어지는 경우가 있습니다. 테이블에 락이 걸려서 이런 현상이 발생하곤 합니다. MS-SQL의 경우 여러 사용자 중 한명이 락이 걸린 경우 역시 조회가 되지 않습니다. 락 걸린 쿼리를 조회하여 강제로 kill하는 방법에 대해 알아보겠습니다.

락으로 의심되는 SPID 조회하기

락으로 의심되는 SPID를 조회하는 방법은 다음과 같이 3가지 방법이 있습니다.

1. SP_LOCK 사용하기

SQL Server에서는 락(Lock)을 확인할 수 있도록 내장 함수 SP_LOCK을 제공하고 있습니다. 사용 방법은 다음과 같습니다.

EXEC SP_LOCK

실행 결과에서 Mode 컬럼의 값이 X인 경우 락이 걸린 것인데 이때 해당 SPID를 확인합니다.

2. SP_WHO2 사용하기

또 다른 MS-SQL 내장 함수로 SP_WHO2를 제공하고 있습니다. 사용 방법은 다음과 같습니다.

EXEC SP_WHO2

실행 결과에서 BlkBy 컬럼에 값이 존재한다면 그것은 락(Lock)걸린 프로세스의 ID입니다.

3. 시스템 테이블 사용하기

다음과 같이 시스템 테이블을 이용해 확인하는 방법도 있습니다. 아래 쿼리를 실행하면 락(Lock)걸린 세션에 대한 정보만 출력됩니다.

 

SELECT   P.*

FROM     MASTER..SYSPROCESSES P 

WHERE    ( 

                  STATUS LIKE 'RUN%' 

         OR       WAITTIME > 0 

         OR       BLOCKED <> 0 

         OR       OPEN_TRAN <> 0 

         OR       EXISTS 

                  ( 

                         SELECT * 

                         FROM   MASTER..SYSPROCESSES P1 

                         WHERE  P.SPID = P1.BLOCKED 

                         AND    P1.SPID <> P1.BLOCKED ) ) 

AND      SPID > 50 

AND      SPID <> @@SPID 

ORDER BY 

         CASE 

                  WHEN STATUS LIKE 'RUN%' THEN 0 

                  ELSE 1 

         END , 

         WAITTIME DESC , 

         OPEN_TRAN DESC

 

LOCK 걸린 SPID 기준으로 실행되고 있는 쿼리 출력

SQL Server의 내장 함수를 이용해 락걸린 SPID 기준으로 현재 실행되고 있는 쿼리를 확인할 수 있습니다. 쿼리 내용을 확인하는 구문은 다음과 같습니다. 락으로 의심되는 SPID를 인자 값으로 넣어서 실행하면 됩니다.

DBCC INPUTBUFFER( [SPID] )

SPID를 이용하여 KILL하기

MS-SQL에서는 SPID를 기준으로 세션을 종료시킬 수 있습니다. 명령어는 다음과 같습니다.

KILL ( [SPID] )

[출처] [MS-SQL] SP_LOCK, KILL - 락 확인 및 강제종료|작성자 seek