RadarURL

데이터베이스
2016.03.28 18:24

[Oracle] Lock 확인 및 Lock 해제

조회 수 640 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

 

 

Lock확인 및 Lock해제는 sys, system 계정으로 sqlplus 및 toad 접속하여 아래의 명령을 실행한다.

 

1. Lock 걸린 테이블 및 세션 확인

 

1) SID, 시리얼번호, 테이블명 확인

 

SELECT
    a.sid, a.serial#, a.username, a.process, b.object_name, 
    DECODE(c.lmode,2,'RS',3,'RX',4,'S',5,'SRX',8,'X','NO') "TABLE LOCK", 
    DECODE(a.command,2,'INSERT',3,'SELECT',6,'UPDATE',7,'DELETE',12,'DROP TABLE',26,'LOCK TABLE','UNknown') "SQL", 
    DECODE(a.lockwait, NULL,'NO wait','Wait') "STATUS" 
FROM
    v$session a, dba_objects b, v$lock c 
WHERE 
    a.sid=c.sid and b.object_id=c.id1 
AND c.type='TM';


2) SID, 테이블명 확인

SELECT 
    vo.session_id, do.object_name, do.owner, do.object_type,do.owner, 
    vo.xidusn, vo.locked_mode 
FROM 
    v$locked_object vo , dba_objects do 
WHERE 
    vo.object_id = do.object_id;

 

 

3) 테이블명, Lock 상태 확인

SELECT  
    T1.object_name, 
    DECODE(locked_mode, 2, 'ROW SHARE', 3, 'ROW EXCLUSIVE',  4, 'SHARE', 5, 'SHARE ROW EXCLUSIVE', 6, 'EXCLUSIVE', 'UNKNOWN') lock_mode 
FROM  
    dba_objects T1, v$locked_object T2 
WHERE 
    T1.object_id = T2.object_id;

 

 

4) LOCK 상태와 세션 문자열 확인
 (출력정렬  스크립트)

set linesize 132 pagesize 66
break on Kill on username on terminal
column Kill heading 'Kill String' format a13
column res heading 'Resource Type' format 999
column id1 format 9999990
column id2 format 9999990
column lmode heading 'Lock Held' format a20
column request heading 'Lock Requested' format a20
column serial# format 99999
column username  format a10  heading "Username"
column terminal heading Term format a6
column tab format a35 heading "Table Name"
column owner format a9
column Address format a18
SELECT 
    nvl(S.USERNAME,'Internal') username,
    nvl(S.TERMINAL,'None') terminal,
    L.SID||','||S.SERIAL# Kill,
    U1.NAME||'.'||substr(T1.NAME,1,20) tab,
    decode(L.LMODE,1,'No Lock',
            2,'Row Share',
            3,'Row Exclusive',
            4,'Share',
            5,'Share Row Exclusive',
            6,'Exclusive',null) lmode,
    decode(L.REQUEST,1,'No Lock',
            2,'Row Share',
            3,'Row Exclusive',
            4,'Share',
            5,'Share Row Exclusive',
            6,'Exclusive',null) request
FROM
    V$LOCK L,
    V$SESSION S,
    SYS.USER$ U1,
    SYS.OBJ$ T1
WHERE        
    L.SID = S.SID
AND T1.OBJ# = decode(L.ID2,0,L.ID1,L.ID2)
AND U1.USER# = T1.OWNER#
AND S.TYPE != 'BACKGROUND'
ORDER BY 1,2,5

 

 

 

2. Lock 걸린 테이블 세션 제거

 

usage) ALTER SYSTEM KILL SESSION 'session ID, 시리얼번호'


ex) ALTER SYSTEM KILL SESSION '189,26359'

 

 

3. PROCESS ID를 찾아내어 OS에서 제거
  (Lock 걸린 테이블의 세션 제거가 안될 경우)
  
1) PID 검색

 

SELECT 
    substr(s.username,1,11) "ORACLE USER", p.pid "PROCESS ID", 
    s.sid "SESSION ID", s.serial#, osuser "OS USER", 
    p.spid "PROC SPID",s.process "SESS SPID", s.lockwait "LOCK WAIT" 
FROM 
    v$process p, v$session s, v$access a 
WHERE 
    a.sid=s.sid
AND p.addr=s.paddr
AND s.username != 'SYS';

 

 

2) 리눅스에서 PID 제거 
위 sql 검색결과에서 Lock걸린 v$session.process 번호를 아래의 pid에 넣으면 된다.


$kill -9 pid

 

 

 

 

출처 : http://blog.naver.com/tchobd/30066708333

TAG •
?

공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 [공지] 공부 게시판 입니다. 처누 2003.08.18 927567
2306 육아,교육 2016년 의대 서열 file JaeSoo 2016.04.21 605
2305 유닉스/리눅스 리눅스 logrotate 에서 로그파일 강제로 rotate 시키기 file JaeSoo 2016.03.30 700
» 데이터베이스 [Oracle] Lock 확인 및 Lock 해제 JaeSoo 2016.03.28 640
2303 웹서버,WAS Tomcat JVM heap memory set 및 size JaeSoo 2016.03.23 703
2302 웹서버,WAS Java 실행 옵션 정리 JaeSoo 2016.03.23 623
2301 응용 프로그래밍 메모리 영역 (code, data, stack, heap) file JaeSoo 2016.03.23 744
2300 유닉스/리눅스 리눅스 시간 맞추기 : Time Server와 Sync (rdate, date) JaeSoo 2016.03.19 705
2299 가상화 vCenter 없이 vSphere 로 ESXi 에 연결해서 가상머신 복사하기 file JaeSoo 2016.03.18 730
2298 가상화 Workstation용 .vmdk를 esxi 전용으로 변환하기 file JaeSoo 2016.03.17 662
2297 하드웨어 J1900 vs 1037u vs D2700 vs D525 vs D2550 vs D2500 file JaeSoo 2016.03.17 586
2296 하드웨어 CPU 온도에 관한 진실 file JaeSoo 2016.03.17 575
2295 윈도우즈 윈도우7 한글입력이 안될때 ctfmon.exe file JaeSoo 2016.03.13 774
2294 윈도우즈 Microsoft IME 입력기가 사라진 현상 JaeSoo 2016.03.13 607
2293 모바일 블루스택 GPU 사용으로 CPU 부하를 줄이는 방법 file JaeSoo 2016.03.07 802
2292 모바일 안드로이드 개발자 옵션(developer options)을 액세스하는 방법 file JaeSoo 2016.03.07 964
2291 모바일 블루스택 설치 및 설정, 레이븐, 히트, 성순매크로 설치 방법 JaeSoo 2016.03.07 1482
2290 윈도우즈 윈도우에서 특정 프로세스 강제 종료하는 방법 (taskkill) file JaeSoo 2016.02.19 872
2289 유닉스/리눅스 [Linux/Unix] 심볼릭 링크(ln) 만들기 및 확인/삭제 JaeSoo 2016.02.19 900
2288 윈도우즈 윈도우 8 웹 브라우저 사용흔적 (Windows 8 Web Browser Artifacts) file JaeSoo 2016.02.13 1043
2287 윈도우즈 '윈도우 7' 에서 폴더 여는 시간이 오래 걸린다면? file JaeSoo 2016.02.12 746
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 ... 124 Next
/ 124


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너