Lock Escalation(락 에스컬레이션) 은 데이터베이스에서 트랜잭션이 획득한 잠금(Lock)의 범위가 증가하여 더 큰 범위를 잠그는 과정을 의미합니다.
즉, 많은 개별 행(row) 잠금을 유지하는 대신, 일정 임계치를 초과하면 테이블 단위 잠금(table-level lock)으로 변경하여 시스템 성능을 최적화합니다.
💡 Oracle에서는 자동 Lock Escalation이 발생하지 않으며, MS SQL Server나 DB2에서는 기본적으로 지원됨.
즉, Oracle은 기본적으로 Row-level Lock을 유지하며, 필요에 따라 수동으로 테이블 잠금을 수행해야 합니다.
Lock Escalation이 필요한 이유는 너무 많은 개별 행을 잠그면 시스템 리소스가 과부하되기 때문입니다.
📌 락 에스컬레이션이 필요한 상황
Oracle은 Lock Escalation을 자동으로 수행하지 않으며, 기본적으로 Row-level Lock을 유지합니다.
대신, 개발자가 직접 Lock을 조정할 수 있는 기능을 제공합니다.
UPDATE employees SET salary = salary * 1.1 WHERE department_id = 10;
UPDATE
문을 실행하면 특정 행(Row)만 잠금이 걸림.LOCK TABLE
문을 사용하여 특정 테이블을 전체 잠금할 수 있음.LOCK TABLE employees IN EXCLUSIVE MODE;
ALTER TABLE sales MODIFY PARTITION p1 READ ONLY;
p1
)을 읽기 전용(Read Only)으로 설정하여 잠금 최소화.TM Lock
이 발생하며, DML 작업과 충돌 가능.ALTER TABLE
)과 DML이 충돌하지 않도록 미리 테이블 잠금 설정 가능.LOCK TABLE employees IN SHARE MODE;
Oracle은 Lock Escalation을 자동으로 수행하지 않으므로, 수동으로 조정해야 합니다.
✅ 1) 대량 업데이트 시 BATCH UPDATE 사용
ROWNUM
을 활용하여 배치 단위로 나누어 업데이트 가능.UPDATE employees
SET salary = salary * 1.1
WHERE employee_id IN (SELECT employee_id FROM employees WHERE department_id = 10 AND ROWNUM <= 1000);
✅ 2) Index 활용하여 Lock 범위 최소화
WHERE
조건에 INDEX가 존재하면 불필요한 Lock 방지 가능.CREATE INDEX idx_emp_dept ON employees(department_id);
✅ 3) Explicit Table Lock 사용 (필요한 경우)
LOCK TABLE employees IN EXCLUSIVE MODE;
✅ 4) Undo Tablespace 및 Redo Log 최적화
UNDO_RETENTION
값을 조정하여 Undo 데이터를 빠르게 정리.ALTER SYSTEM SET UNDO_RETENTION=900;
LOCK TABLE ...
사용).🚀 Lock Escalation은 Oracle에서는 자동 수행되지 않으며, 대신 수동으로 Lock을 조정하여 성능을 최적화하는 것이 중요함!
윈도우 운영체제의 노트북에서는 iPhone 유선 테더링이 잘 안되는 경우가 많습니다. 보통 iPhone의 드라이버가 설치가 안되있어서인…
안녕하세요, 혹시 이런 생각해 본 적 없으신가요? "내가 투자한 회사는 누가 감시하고, 어떻게 운영될까?" 오늘은…
1. Gemini CLI란 무엇인가요? Gemini CLI는 터미널 환경에서 직접 Gemini 모델과 상호작용할 수 있도록 만들어진…
과적합은 머신러닝에서 학습용데이터를 과하게 학습하여, 실제데이터를 예측하지 못하는 현상을 말합니다. 인공지능(AI)의 학습 방법은 우리가 시험공부를…