본문 바로가기
데이터베이스/Postgresql

[PostgreSQL] 테이블 lock 조회 및 kill하기

by cbwstar 2021. 7. 16.
728x90
반응형

현재 수행중인 SQL 전체 조회 

select  datname, 
        pid, 
        usename, 
        application_name, 
        client_addr, 
        client_port, 
        backend_start, 
        query_start, 
        wait_event_type, 
        state, 
        backend_xmin
        query 
from pg_stat_activity;

 

위 쿼리 실행시 현재 DB에서 돌고 있는 SQL 전체를 조회할 수 있다.

datid oid 데이터베이스oid
datname name 데이터베이스 이름
pid integer 프로세스id
usesysid oid 사용자고유번호
usename name 사용자이름
application_name text 응용프로그램이름
client_addr inet 접속ip
client_hostname text 접속 호스트 이름
client_port integer 접속한 TCP 포트
backend_start timestamp 서버 접속시간
xact_start timestamp 트랜잭션 시작 시간
query_satrt timestamp 쿼리 시작 시간
state_change timestamp state 마지막 변경 시간
waiting boolean 대기중 = true
state text 상태 정보 (하단 참조)
query text state=active 인 row에 대해 실행중인쿼리

state (상태 정보)

active : 쿼리 실행중

idle : 새로운 명령 대기중

idle in transaction : 트랜잭션은 있지만 현재 실행중인 쿼리 없음

idle in transaction (aborted) : 트랜잭션은 있고 실행중인 쿼리는 없으나 트랜잭션에 오류가 발생

fastpath function call : 함수 실행중

disabled : track_activities 무효

 

LOCK 걸린 테이블 확인

SELECT  t.relname,
        l.locktype,
        page,
        virtualtransaction,
        pid,
        mode,
        granted
FROM pg_locks l,
	 pg_stat_all_tables t
WHERE l.relation = t.relid
ORDER BY relation ASC;

 

현재 테이블에 lock을 확인 할 수 있다. 기본적으로 대부분의 lock 테이블은 괜찮으나 RowExclusiveLock 이 검색된다면 해당 테이블에 접근이 지연되어 다른 쿼리에도 영향을 미칠 수 있으므로 반드시 잡고있는 트랜잭션이나 서버 상태 등을 점검하여 lock을 해제 해 주는 작업이 필요하다.

 

 

 

해당 작업(process) kill

SELECT pg_cancel_backend([pid]);

SELECT pg_terminate_backend([pid]) FROM pg_stat_activity;

 

pg_cancel_backend는 해당 PID만 중지시키고, pg_terminate_backend는 해당 PID와 연계된 모든 상위 쿼리 프로세스를 종료시킨다. 따라서 pg_cancel_backend로 해당 작업이 종료 되는지 먼저 체크한 뒤, 중지 되지 않는다면 pg_terminate_backend를 수행하여 해당 프로세스를 종료시키도록 한다.



출처: https://kwomy.tistory.com/80 [Kwomy's DB World]

728x90
반응형

댓글



"이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다."

loading