데이터베이스

Scalable Sequence (오라클18c)

Oracle 18c에서 Scalable Sequence(확장 가능한 시퀀스)는 대량의 트랜잭션이 발생하는 환경에서 시퀀스 생성의 성능을 향상시키기 위해 도입된 기능입니다. 이는 특히 다중 노드 RAC(Real Application Clusters) 환경이나 병렬 트랜잭션이 많은 OLTP(Online Transaction Processing) 시스템에서 성능 병목을 줄이는 데 도움이 됩니다.

🚀 Scalable Sequence란?

Oracle에서 시퀀스는 NEXTVAL을 호출할 때 단일 시퀀스 객체를 공유하는 방식으로 동작합니다. 하지만, 다중 세션에서 동시 접근할 경우 잠금 경합(latch contention)이 발생하여 성능 저하가 일어날 수 있습니다.

Oracle 18c에서는 SCALABLE 옵션을 사용하여 이러한 경합을 최소화하고, 빠르고 확장 가능한 시퀀스 생성을 가능하게 합니다.

🛠 Scalable Sequence 생성 방법

Oracle 18c에서 Scalable 시퀀스를 생성하려면 SCALE 키워드를 추가하면 됩니다. (또는 SCALE EXTEND )

CREATE SEQUENCE scalable_seq 
START WITH 1
INCREMENT BY 1
SCALE;
  • SCALE: 시퀀스를 확장 가능한 방식으로 생성 (SCALE EXTEND 키워드로도 사용 가능)
  • START WITH 1: 시퀀스 시작 값
  • INCREMENT BY 1: 1씩 증가

🔍 Scalable Sequence의 특징

  1. 세션별 캐싱 및 병렬 증가
    • 기존 시퀀스는 NEXTVAL 호출 시, 단일 시퀀스 객체에서 값을 가져오지만, Scalable Sequence는 여러 세션이 동시에 시퀀스 값을 증가시킬 수 있도록 최적화됩니다.
    • 여러 개의 시퀀스 인스턴스가 병렬적으로 관리되므로 경합이 줄어듭니다.
  2. NOORDER, NOCACHE 자동 적용
    • SCALE을 적용하면 자동으로 NOORDERNOCACHE가 활성화됩니다.
    • NOORDER: 시퀀스 값이 순차적이지 않을 수도 있음.
    • NOCACHE: 캐싱을 비활성화하여 각 세션이 개별적으로 시퀀스를 관리.
  3. Oracle RAC 환경에서 효과적
    • RAC(Real Application Cluster) 환경에서 여러 노드가 동시에 시퀀스를 사용하는 경우 잠금 경합을 피하면서도 성능을 최적화할 수 있음.

⚠️ Scalable Sequence 주의점

  1. 순차적이지 않을 수 있음
    • SCALE을 사용하면 순서가 보장되지 않습니다.
    • 예를 들어, 트랜잭션이 다중 노드에서 실행될 경우, 시퀀스 값이 예상과 다르게 증가할 수 있습니다. (즉, 1001 → 1002 → 1003이 아닌 1001 → 1050 → 1020 등으로 증가할 수 있음)
    • 순서를 엄격하게 유지해야 하는 경우 사용을 피해야 합니다.
  2. CYCLE과 함께 사용할 수 없음
    • SCALE 옵션이 설정된 시퀀스는 CYCLE 옵션과 함께 사용할 수 없습니다.
      (즉, 일정 범위 이후 다시 1로 순환하는 시퀀스를 만들 수 없음)
  3. CACHE를 지정할 수 없음
    • SCALE을 사용하면 자동으로 NOCACHE가 적용됩니다.

📌 예제: Scalable Sequence 사용

-- 확장 가능한 시퀀스 생성
CREATE SEQUENCE my_scalable_seq
START WITH 1
INCREMENT BY 1
SCALE;

-- 시퀀스 값 가져오기
SELECT my_scalable_seq.NEXTVAL FROM dual;

🔥 Scalable Sequence vs 기존 시퀀스 비교

기능기존 시퀀스Scalable 시퀀스
성능동시 트랜잭션 증가 시 경합 발생동시 트랜잭션에서도 경합 최소화
순차성순서 보장순서 보장 안됨 (NOORDER)
캐싱CACHE 사용 가능NOCACHE (자동 설정)
RAC 지원가능하지만 경합 발생 가능RAC 환경에서 성능 최적화
CYCLE 지원가능불가능

결론

  • 고속 트랜잭션 처리 및 다중 세션 환경에서는 Scalable Sequence를 사용하면 성능을 대폭 향상할 수 있습니다.
  • 하지만, 순차적 값이 필수적인 경우에는 사용을 피해야 합니다.
  • 특히 RAC 환경, OLTP 시스템, 대규모 데이터 삽입이 필요한 경우 유용합니다.

🔹 Oracle 18c에서 Scalable Sequence를 활용하면 성능을 최적화하면서도 경합을 줄일 수 있으므로, 특정 워크로드에 맞게 도입을 고려해보는 것이 좋습니다! 🚀

zerg96

Recent Posts

MCP(Model Context Protocol)

오늘은 AI 생태계에 혁신적인 변화를 가져올 것으로 예상되는 MCP(Model Context Protocol)에 대해 상세히 알아보겠습니다. 2024년…

1주 ago

TPM(Trusted Platform Module)

1. TPM이란? TPM(Trusted Platform Module)은 국제 표준 기반의 보안 하드웨어 칩으로, 컴퓨터나 디지털 장비 내에서…

1주 ago

BitLocker

BitLocker는 Microsoft Windows 운영 체제에 내장된 디스크 전체 암호화(Full Disk Encryption) 기능입니다. 기업 환경뿐만 아니라…

1주 ago

《데블스 플랜 시즌2》: 게임인가, 연애인가? 소희 이렇게까지..?

시즌2, 기대했는데... 실망도 두 배!두뇌싸움을 기대했는데, 전략도 없는 자기들만의 감정에 따른 편가르기, 정치싸움이 되어 버린…

2주 ago

BPF도어(BPFdoor)

BPF(Berkeley Packet Filter) 도어는 해커가 관리자 몰래 뒷문을 새로 만든 것입니다.해커가 명령을 내려 특정 데이터들을 뒷문을…

2주 ago

IPC (Inter-Process Communication)

1. IPC의 개념과 목적 1.1 IPC란 무엇인가? IPC (Inter-Process Communication)는 운영체제 내의 서로 독립적인 프로세스…

2주 ago