기본 콘텐츠로 건너뛰기

8월, 2025의 게시물 표시

Lock정보가 없지만 대기타고 있는 쿼리를 찾아라! SQL Server

영상버전 :  https://youtu.be/4ssE81DwGr4 얼마전에 며칠을 고생해서 원인 쿼리를 찾은 이야기 입니다.  보통 쿼리는 Lock에 걸려서 대기 상태에 있다면 쉽게 찾는데요..  Lock에 걸리지 않은 상태로 대기를 타는 경우가 있습니다.  Sql server 에서 일단 쉽게 찾는 방법은 Sp_who2 를 실행하는 것이죠.  그냥 SSMS에서 서버에 접속해서 새 쿼리창을 열고  Sp_who2 라고 입력하고  실행해버리면 현재 물려있는 모든 세션의 정보가 나타납니다.  여기서 Blkby 라는 필드에서 숫자가 보이면 그 숫자의 SPID가 원인으로  숫자가 쓰여진 곳의 SPID가 멈춰 있다는 이야기 입니다.  이렇게 원인 세션을 찾고 그 세션이 어떤 쿼리를 던지고 있는지를 찾아서  Kill을 할지, 다른 어떤 액션을 취할지를 택하면 됩니다.  Kill을 하고 싶으면 Kill 999 처럼 SPID를 kill 뒤에 적어주면 되구요..  Blkby에 적힌 숫자를 입력하면 원인 쿼리가 강제 종료 되는데요,  이게 INSERT나 UPDATE의 경우가 많아서  데이터 유실이 될 가능성이 높기 때문에  저 같은 경우는 원인 쿼리의 문제를 해결할 방법만 알려주고  자연히 사라질 때 까지 기다리기는 합니다.  그래도 급히 대응이 필요하거나  아무리 기다려도 사라지지 않는 경우에는  Kill밖에 없겠죠.  지난 번에는 개발팀에서  Begin tran을 던지고 쿼리를 던진 뒤에 Commit이나 rollback을 하지 않아서  Blkby가 보여서 문의했더니  자신들의 실수임을 확인해서 쉽게 끝났지만, 이번에는 Blkby가 뜨지 않은채로  많은 세션들이 SUSPEND가 되어버렸죠.  보통 커넥션 풀을 사용한다 하더라도  SUSPEND가...