[MSSQL] DB single_user 변경시 deadlock 이슈
DB Troubleshooting/MSSQL 2021. 12. 29. 19:54
※현상
DB를 single_user에서 multi_user로 변경하는 도중 프로세스 Deadlock 발생
원인
DB 커넥션이 존재하는 상황에서, 사용자 세션이 master를 바라보는 도중 DB 커넥션을 모두 off시켜,
사용자 세션이 DB를 바라보지 않아 system 내부에서 DB의 소유자를 찾지 못하는 상태
deadlock이 발생하는 세션을 끊으려 하여도 사용자 세션이 아닌 시스템 세션이라 kill이 불가한 상태
해결방안
1번으로 작업해야 하지만, 이미 deadlock이 발생한 상태라면 2번으로 해결
1. 작업하려는 DB를 소유하고 single_user로 변경
use [작업DB]
alter database [작업DB] set single_user WITH ROLLBACK IMMEDIATE-- immediate 커넥션 한번에 off
go
-- 작업 할 쿼리 내역
alter database [작업DB] set multi_user
go
2. Deadlock 발생 시, DB 재기동 후 아래 쿼리 실행
SET DEADLOCK_PRIORITY HIGH -- 교착상태 최상위 레벨로 격상
GO
ALTER DATABASE [작업DB] SET MULTI_USER WITH ROLLBACK IMMEDIATE -- 작업 DB multi_user로 변경
GO
-- https://myadventuresincoding.wordpress.com/2014/03/06/sql-server-alter-database-in-single-user-mode-to-multi-user-mode/
'DB Troubleshooting > MSSQL' 카테고리의 다른 글
Unable to manually failover a SQL Availability Group ( Cluster Log 추출 ) (0) | 2022.04.07 |
---|---|
MSSQL 이중화(AlwaysOn) 구성 후 쿼럼(Quorum) 장비 이슈로, 쿼럼 삭제 or 재구성 작업 (0) | 2022.04.07 |