Azure Virtual Machines의 Oracle 데이터베이스 아키텍처
적용 대상: ✔️ Linux VM
이 문서에는 Azure에 고가용성 Oracle 데이터베이스를 배포하는 방법에 대한 정보가 포함되어 있습니다. 또한 이 가이드에서는 재해 복구 시 고려 사항을 자세히 살펴봅니다. 이러한 아키텍처는 고객 배포를 기반으로 작성되었습니다. 이 가이드는 Oracle Database Enterprise Edition에만 적용됩니다.
Oracle 데이터베이스의 성능을 최대화하는 방법에 관심이 있으면 Azure에서 Oracle 데이터베이스 설계 및 구현을 참조하세요.
필수 조건
- 가용성 영역과 같은 Azure의 여러 개념 숙지
- Oracle Database Enterprise Edition 12c 이상
- 이 문서의 솔루션을 사용할 때 적용되는 라이선스 영향 숙지
- 정의된 RPO 및 RTO 요구 사항
Oracle 데이터베이스의 고가용성
클라우드에서 고가용성을 달성하는 것은 모든 조직의 계획 및 설계에서 중요한 부분입니다. Azure는 가용성 영역 및 가용성 영역을 사용할 수 없는 지역을 위한 가용성 집합을 제공합니다. 클라우드용으로 설계하는 방법에 대한 자세한 내용은 Azure Virtual Machines의 가용성 옵션을 참조하세요.
Oracle은 클라우드 네이티브 도구와 제품 외에도 Azure에서 설정할 수 있는 다음과 같은 고가용성 솔루션을 제공합니다.
이 가이드에서는 이러한 각 솔루션의 참조 아키텍처를 설명합니다.
클라우드용 애플리케이션을 마이그레이션하거나 만들 때 재시도 패턴 및 회로 차단기 패턴과 같은 클라우드 네이티브 패턴을 사용하는 것이 좋습니다. 애플리케이션의 복원력을 높이는 데 도움이 되는 다른 패턴은 클라우드 디자인 패턴 가이드를 참조하세요.
클라우드의 Oracle RAC
Oracle RAC(Real Application Cluster)는 여러 인스턴스가 단일 데이터베이스 스토리지에 액세스하게 하여 고객이 높은 처리량을 얻을 수 있게 도와주는 Oracle의 솔루션입니다. 이 패턴은 모두 공유 아키텍처입니다. Oracle RAC는 고가용성 온-프레미스에 사용할 수 있지만 Oracle RAC 단독으로는 클라우드의 고가용성에 사용할 수 없습니다. Oracle RAC는 랙 수준 또는 데이터 센터 수준 오류가 아닌 인스턴스 수준 오류로부터만 보호합니다. 이러한 이유로 Oracle에서는 단일 인스턴스든 아니면 RAC든 상관없이 고가용성을 위해 데이터베이스에 Oracle Data Guard를 사용할 것을 권장합니다.
일반적으로 고객은 중요 업무용 애플리케이션을 실행하기 위해 높은 SLA를 요구합니다. Oracle은 현재 Azure에서 Oracle RAC를 인증하거나 지원하지 않습니다. 그러나 Azure는 인스턴스 수준 오류로부터 보호하는 데 도움이 되는 가용성 영역 및 계획된 유지 관리 기간 등의 기능을 제공합니다. 이러한 제품 외에도 높은 성능과 복원력을 제공하는 Oracle Data Guard, Oracle GoldenGate 및 Oracle Sharding을 사용할 수 있습니다. 이러한 기술은 랙 수준, 데이터 센터 수준 및 지리적 정치적 오류로부터 데이터베이스를 보호하는 데 도움이 될 수 있습니다.
Oracle Data Guard 또는 GoldenGate를 사용하는 여러 가용성 영역에서 Oracle Database를 실행하면 99.99%의 작동 시간 SLA를 달성할 수 있습니다. 가용성 영역이 아직 없는 Azure 지역에서는 가용성 집합을 사용하여 99.95%의 작동 시간 SLA를 달성할 수 있습니다.
참고 항목
고객의 작동 시간 목표가 Microsoft에서 제공하는 작동 시간 SLA보다 훨씬 높을 수 있습니다.
Oracle 데이터베이스의 재해 복구
중요 업무용 애플리케이션을 클라우드에 호스팅하는 경우 고가용성 및 재해 복구를 설계하는 것이 중요합니다.
Oracle Database Enterprise Edition의 경우 Oracle Data Guard는 재해 복구를 위한 유용한 기능입니다. 쌍을 이루는 Azure 지역에 대기 데이터베이스 인스턴스를 설정하고 재해 복구를 위한 Data Guard 장애 조치(failover)를 설정할 수 있습니다. 데이터가 손실되지 않도록 Active Data Guard뿐 아니라 Oracle Data Guard Far Sync 인스턴스도 배포하는 것이 좋습니다.
장거리 데이터 복제의 경우 원거리 동기화를 활용하는 것이 좋습니다. 원거리 동기화는 Oracle Active Data Guard 기능입니다.
참고 항목
Far Sync를 사용하도록 설정하면 Active Data Guard 라이선스가 필요합니다. 라이선스에 미치는 영향에 대해서는 Oracle 담당자에게 문의하세요.
Oracle Far Sync는 Far Sync 인스턴스라는 중간 서버를 도입하여 주 데이터베이스와 보조 데이터베이스 간의 장거리 주소를 지정합니다. 이 서버는 주 데이터베이스에서 다시 실행 데이터를 받은 다음 대기 데이터베이스로 전달합니다. 따라서 원거리 동기화 인스턴스는 통신 시간을 줄이기 위해 주 인스턴스에 더 가깝게 배치됩니다. 그런 다음 Far Sync 서버는 다시 실행 데이터를 보조 데이터베이스로 비동기적으로 전송합니다.
참고 항목
Oracle Standard Edition 데이터베이스를 사용하는 경우 DBVisit 대기 또는 Tessell과 같은 고가용성 및 재해 복구를 설정할 수 있는 ISV 솔루션이 있습니다.
참조 아키텍처
Oracle 데이터 가드
Oracle Data Guard는 엔터프라이즈 데이터의 고가용성, 데이터 보호 및 재해 복구를 보장합니다. Data Guard는 대기 데이터베이스를 트랜잭션 측면에서 일관적인 주 데이터베이스 복사본으로 유지 관리합니다. 주 데이터베이스와 보조 데이터베이스 간의 거리와 애플리케이션에서 허용하는 대기 시간에 따라 동기 또는 비동기 복제를 설정할 수 있습니다.
Fast-Start Failover를 사용하는 Oracle Data Guard
Data Guard는 FSFO(빠른 시작 장애 조치)를 사용하여 배포할 수 있습니다. 빠른 시작-장애 조치(failover)는 Data Guard Broker 구성 내에서 제공되는 기능입니다. 이 기능을 사용하면 오류가 발생할 경우 자동으로 장애 조치(failover )할 수 있습니다. 고객이 사용하는 기본 시간은 30초이지만 요구 사항에 따라 조정할 수 있습니다. 이 소위 OperationTimeout은 배포 중에 정의하는 Data Guard 속성의 일부입니다.
Data Guard가 이 속성에서 작동하는 방법
Data Guards 작업은 주 데이터베이스와 보조 데이터베이스의 상태와 상태를 지속적으로 모니터링하는 것입니다. FSFO(Fast-Start-Failover)를 사용하도록 설정하는 즉시 관찰자 프로세스가 트리거되고 일정한 간격으로 상태를 검토하여 지정된 시간에 고가용성을 보장합니다.
이제 주 데이터베이스를 사용할 수 없게 되면 관찰자와 Data Guard Broker가 이 중단을 감지합니다. 따라서 30초의 OperationTimeout 매개 변수는 Broker가 추가 작업을 수행하기 전에 주 데이터베이스의 응답을 기다리는 시간을 지정합니다.
그러면 주 복제본이 이 30초 창 내에서 응답하지 않으면 관찰자는 주 복제본에 액세스할 수 없다고 가정하고 장애 조치(failover) 프로세스를 시작합니다.
Broker는 즉시 대기 데이터베이스를 기본 상태로 승격하여 역할을 전환하고 애플리케이션이 대기 상태에서 신속하게 다시 시작할 수 있도록 합니다.
이 시간 동안 Broker는 트랜잭션이 대기 상태인지도 확인합니다. 최대 가용성 또는 최대 보호가 될 수 있는 구성 모드를 사용하면 동기 복제에서 데이터 손실을 최소화할 수 있습니다. Oracle 데이터베이스는 고가용성을 위해 여러 가용성 영역에 배치됩니다. 각 영역은 독립된 전원, 냉각 및 네트워킹을 갖춘 하나 이상의 데이터 센터로 구성됩니다. 복원력을 보장하려면 활성화된 모든 지역에서 적어도 3개의 별도 영역이 필요합니다. Azure 지역 내에서 가용성 영역을 물리적으로 분리하면 데이터를 데이터 센터 오류로부터 보호할 수 있습니다. 또한 두 개의 FSFO 관찰자는 실패 시 보조 데이터베이스로 장애 조치(failover)를 시작하기 위해 두 개의 가용성 영역에 설정됩니다. 장애 조치(failover)가 발생하고 이전 주 데이터베이스를 다시 사용할 수 있게 된 후 복구할 수 있습니다. Data Guard Broker는 이 프로세스를 용이하게 합니다.
궁극적으로 계획되었거나 계획되지 않은 중단으로 인해 주 데이터베이스를 사용할 수 없는 경우 Data Guard는 대기 데이터베이스로 전환하거나 장애 조치합니다.
이 기능은 별도의 가상 머신에서 관찰자를 설정하여 추가 복원력을 제공할 수 있습니다. 따라서 관찰자를 경량 VM에 배포합니다. 이 방법을 사용하면 고가용성 및 복원력을 사용할 수 있습니다.
Oracle Database 12.2 이상 버전에서는 Oracle Data Guard broker 하나에 여러 관찰자를 구성할 수도 있습니다. 한 관찰자 및 보조 데이터베이스가 가동 중지 시간을 경험하는 경우 추가 가용성을 제공합니다. Data Guard Broker 및 장점에 대한 자세한 내용은 Oracle Data Guard Broker 개념을 참조하세요.
다음 다이어그램에서는 복구 시간이 5분 미만인 Far Sync가 없는 Oracle Data Guard 설치를 보여 줍니다.
Oracle 데이터베이스는 고가용성을 위해 여러 가용성 영역에 배치됩니다. 각 영역은 독립된 전원, 냉각 및 네트워킹을 갖춘 하나 이상의 데이터 센터로 구성됩니다. 복원력을 보장하려면 활성화된 모든 지역에서 적어도 3개의 별도 영역이 필요합니다. Azure 지역 내에서 가용성 영역을 물리적으로 분리하면 데이터를 데이터 센터 오류로부터 보호할 수 있습니다. 또한 두 개의 FSFO 관찰자는 실패 시 보조 데이터베이스로 장애 조치(failover)를 시작하기 위해 두 개의 가용성 영역에 설정됩니다.
참고 항목
대칭 Data Guard 배포를 계획하는 경우 가용성 영역 3에 관찰자가 한 명 더 필요합니다.
또한 데이터베이스 계층에 대한 개요를 유지하려면 Oracle Enterprise Manager를 배포하는 것이 좋습니다. Azure Monitor는 다음 메트릭을 사용하여 배포하는 것이 좋습니다. 디스크 모니터링:
- OS 디스크 IOPS 사용 비율
- 데이터 디스크 IOPS 사용 비율
- Data Disk Read Bytes/Sec
- Data Disk Writes Bytes/Sec
- 디스크 큐 깊이
- Lun당 %의 디스크 대역폭
위의 정보 외에도 VM 인사이트도 사용하도록 설정하는 것이 좋습니다.
Virtual Machine은 AWR 평가에 따라 선택됩니다. 자세한 내용은 Oracle 용량 계획을 검토하세요. 제한된 코어 vCPU를 사용하여 라이선스 비용을 절감하고 성능을 극대화하는 것이 좋습니다.
디스크 유형의 선택은 AWR 평가의 출력에 따라 달라집니다.
위에서 설명한 것처럼 Far Sync는 장거리를 극복하는 지역 간에 복제하는 시나리오에서 주로 사용되는 기능입니다. 이 시나리오를 참조하여 Oracle Active Data Guard Far Sync는 Oracle 데이터베이스에 대해 데이터 손실 방지 기능을 제공하지 않습니다. Oracle Far Sync 인스턴스는 별도의 VM에 설치해야 합니다.
운영 체제를 참조하는 파일에는 프리미엄 SSD v2가 지원되지 않습니다. 자세한 내용은 프리미엄 SSD v2 배포를 참조하세요.
백업 대상으로 Azure Premium Files가 사용됩니다. 이 솔루션은 가장 성능이 좋습니다. Azure Blob Storage를 Backup 대상으로 사용할 수도 있습니다. 항상 가장 적합한 옵션을 테스트해야 합니다. Oracle 데이터베이스 백업 전략도 방문하세요.
Oracle Data Guard Far Sync
위에서 설명한 것처럼 Far Sync는 장거리를 극복하는 지역 간에 복제하는 시나리오에서 주로 사용되는 기능입니다. 이 시나리오를 참조하여 Oracle Far Sync는 Oracle 데이터베이스에 대해 데이터 손실 방지 기능을 제공하지 않습니다. Oracle Far Sync 인스턴스는 별도의 VM에 설치해야 합니다.
데이터 무손실 보호를 위해 주 데이터베이스와 Far Sync 인스턴스 간에 동기 통신이 필요합니다. Far Sync 인스턴스는 동기 방식으로 주 데이터베이스에서 다시 실행을 받아서 모든 대기 데이터베이스에 즉시 비동기 방식으로 전달합니다. 뿐만 아니라 이 설정은 모든 대기 데이터베이스가 아닌 Far Sync 인스턴스에만 다시 실행을 보내면 되기 때문에 주 데이터베이스의 오버헤드를 줄입니다. Far Sync 인스턴스가 실패하면 Active Data Guard는 주 데이터베이스에서 보조 데이터베이스로의 비동기 전송을 자동으로 사용하여 거의 0에 가까운 데이터 손실 보호를 유지합니다. 복원력을 더 높이려는 고객은 주 데이터베이스 및 보조 데이터베이스를 비롯한 각 데이터베이스 인스턴스마다 여러 개의 Far Sync 인스턴스를 배포하면 됩니다.
다음 다이어그램은 Oracle Active Data Guard FSFO 및 Far Sync를 사용하여 고가용성 및 재해 복구를 달성하는 아키텍처입니다.
참고 항목
대칭 원거리 동기화 배포를 계획하는 경우 두 번째 지역에 하나 이상의 Far Sync 인스턴스가 필요합니다.
Oracle GoldenGate
GoldenGate를 사용하면 엔터프라이즈 전체의 여러 이기종 플랫폼 간에 데이터를 트랜잭션 수준에서 교환 및 조작할 수 있습니다. GoldenGate는 기존 인프라의 트랜잭션 무결성 및 최소 오버헤드로 커밋된 트랜잭션을 이동합니다. GoldenGate의 모듈식 아키텍처는 다양한 토폴로지에서 선택한 데이터 레코드, 트랜잭션 변경 내용, DDL(데이터 정의 언어) 변경 내용을 유연하게 추출하고 복제할 수 있습니다.
Oracle GoldenGate를 사용하면 양방향 복제를 제공하여 고가용성 데이터베이스를 구성할 수 있습니다. 이 방법을 사용하면 애플리케이션 수준 인식이 필요한 다중 마스터 또는 활성-활성 구성을 설정할 수 있습니다. 다음 다이어그램은 Azure의 Oracle GoldenGate 활성-활성 설정에 권장되는 아키텍처입니다. 다음 아키텍처에서 Oracle 데이터베이스는 라이선스 비용을 절감하고 성능을 최대화하기 위해 제약이 있는 코어 vCPU가 포함된 하이퍼스레드 메모리 최적화 가상 머신을 사용하여 구성되었습니다. 이 아키텍처에서는 높은 성능과 가용성을 얻기 위해 여러 프리미엄 또는 울트라 디스크(관리 디스크)를 사용합니다.
참고 항목
현재 가용성 영역을 사용할 수 없는 지역에서는 가용성 집합을 사용하여 비슷한 아키텍처를 설정할 수 있습니다.
Oracle GoldenGate에는 Oracle 데이터베이스 서버 간에 데이터를 비동기적으로 복제할 수 있는 추출, 펌프, Replicat 등의 프로세스가 있습니다. 이러한 프로세스를 통해 양방향 복제를 설정하면 가용성 영역 수준에서 가동 중지 시간이 발생하더라도 데이터베이스의 고가용성을 보장할 수 있습니다.
이전 다이어그램에서 추출 프로세스는 Oracle 데이터베이스와 동일한 서버에서 실행됩니다. 데이터 펌프 프로세스와 Replicat 프로세스는 동일한 가용성 영역에 있는 별도의 서버에서 실행됩니다. Replicat 프로세스는 다른 가용성 영역에 있는 데이터베이스에서 데이터를 수신하여 해당 가용성 영역의 Oracle 데이터베이스에 데이터를 커밋하는 데 사용됩니다. 마찬가지로, 데이터 펌프 프로세스는 추출 프로세스에서 추출한 데이터를 다른 가용성 영역의 Replicat 프로세스로 보냅니다.
위의 아키텍처 다이어그램은 별도의 서버에 구성된 데이터 펌프 및 Replicat 프로세스를 보여주지만, 서버의 용량과 사용량에 따라 동일한 서버에 모든 Oracle GoldenGate 프로세스를 설정할 수도 있습니다. 서버의 사용량 패턴을 파악하려면 항상 Azure에서 AWR 보고서와 메트릭을 확인하세요.
다른 가용성 영역 또는 다른 지역에 Oracle GoldenGate 양방향 복제를 설정하는 경우 서로 다른 구성 요소 간의 대기 시간이 애플리케이션에서 허용하는 수준이어야 합니다. 가용성 영역과 지역 간의 대기 시간이 다를 수 있습니다. 대기 시간은 여러 요인에 따라 달라집니다. 서로 다른 가용성 영역 또는 지역에 있는 애플리케이션 계층과 데이터베이스 계층 간의 성능 테스트를 설정하는 것이 좋습니다. 이 테스트를 통해 구성이 애플리케이션 성능 요구 사항을 충족하는지 확인할 수 있습니다.
애플리케이션 계층은 자체 서브넷에 설정할 수 있으며 데이터베이스 계층은 자체 서브넷에 분리할 수 있습니다. 가능하다면 Azure Application Gateway를 사용하여 애플리케이션 서버 간에 트래픽을 분산하는 것이 좋습니다. Application Gateway는 견고한 웹 트래픽 부하 분산 장치입니다. Application Gateway는 사용자 세션을 동일한 서버에 유지하여 데이터베이스의 충돌을 최소화하는 쿠키 기반 세션 선호도를 제공합니다. Application Gateway의 대안은 Azure Load Balancer 및 Azure Traffic Manager입니다.
Oracle 분할
분할은 Oracle 12.2에서 도입된 데이터 계층 패턴입니다. 분할을 통해 독립 데이터베이스의 데이터를 수평으로 분할하고 스케일링할 수 있습니다. 각 데이터베이스가 전용 가상 머신에 호스트되는 비공유 아키텍처입니다. 이 패턴을 사용하면 복원력과 가용성이 향상될 뿐 아니라 읽기 및 쓰기 처리량도 높아집니다.
이 패턴은 단일 실패 지점이 없으며, 오류 격리를 제공하고 가동 중지 시간 없이 롤링 업그레이드가 가능합니다. 익스텐트 하나의 가동 중지 시간 또는 데이터 센터 수준 오류의 가동 중지 시간은 다른 데이터 센터에 있는 다른 익스텐트의 성능 또는 가용성에 영향을 주지 않습니다.
분할은 처리량이 많아서 가동 중지 시간을 허용할 수 없는 OLTP 애플리케이션에 적합합니다. 분할 키가 동일한 모든 행은 항상 동일한 익스텐트에 있습니다. 따라서 성능이 향상되어 높은 일관성을 제공합니다. 분할을 사용하는 애플리케이션에는 일관된 해시, 범위, 목록 또는 복합과 같은 잘 정의된 데이터 모델 및 데이터 분산 전략이 있어야 합니다. 이 전략은 주로 분할 키(예: customerId 또는 accountNum)를 사용하여 데이터에 액세스합니다. 또한 분할을 사용하여 특정 데이터 세트를 최종 고객과 더 가까이에 저장하면 성능 및 규정 준수 요구 사항을 충족하는 데 도움이 됩니다.
고가용성 및 재해 복구를 위해 익스텐트를 복제하는 것이 좋습니다. 이 설정은 Oracle Data Guard 또는 Oracle GoldenGate와 같은 Oracle 기술을 사용하여 수행할 수 있습니다. 복제 단위는 익스텐트, 익스텐트의 일부 또는 익스텐트 그룹입니다. 하나 이상의 익스텐트가 중단되거나 속도가 저하되어도 분할된 데이터베이스의 가용성에는 영향을 주지 않습니다.
고가용성을 원하는 경우 주 익스텐트가 배치된 가용성 영역에 대기 익스텐트를 배치하면 됩니다. 재해 복구를 원하는 경우 대기 익스텐트가 다른 지역에 있어도 됩니다. 익스텐트를 여러 지역에 배포하여 해당 지역의 트래픽을 처리할 수도 있습니다. 분할된 데이터베이스의 고가용성 및 복제를 구성하는 방법에 대한 자세한 내용은 익스텐트 수준 고가용성을 참조하세요.
Oracle 분할은 주로 다음과 같은 구성 요소로 구성됩니다. 자세한 내용은 Oracle 분할 개요의 다음 항목을 참조하세요.
익스텐트 카탈로그. 특수 용도의 Oracle 데이터베이스로, 모든 익스텐트 데이터베이스 구성 데이터를 저장하는 영구 저장소입니다. 익스텐트 추가 또는 제거, 데이터 매핑, 익스텐트 데이터베이스의 DDL과 같은 모든 구성 변경은 익스텐트 카탈로그에서 시작됩니다. 익스텐트 카탈로그에는 SDB에 있는 모든 중복 테이블의 마스터 복사본도 포함됩니다.
익스텐트 카탈로그는 구체화된 뷰를 사용하여 모든 익스텐트에 있는 중복 테이블의 변경 내용을 자동으로 복제합니다. 또한 익스텐트 카탈로그 데이터베이스는 분할 키를 지정하지 않는 다중 익스텐트 쿼리를 처리하는 데 사용되는 쿼리 코디네이터 역할을 합니다.
익스텐트 카탈로그 고가용성을 위해 Oracle Data Guard를 가용성 영역 또는 가용성 집합과 함께 사용하는 것이 가장 좋습니다. 익스텐트 카탈로그의 가용성은 분할된 데이터베이스의 가용성에 영향을 주지 않습니다. 익스텐트 카탈로그의 가동 중지 시간은 ata Guard 장애 조치(failover)가 완료되는 짧은 기간 동안 유지 관리 작업 및 다중 익스텐트 쿼리에만 영향을 줍니다. SDB는 계속해서 온라인 트랜잭션을 라우팅하고 실행합니다. 카탈로그 중단은 영향을 미치지 않습니다.
익스텐트 디렉터. 익스텐트가 상주하는 각 지역/가용성 영역에 배포해야 하는 가벼운 서비스입니다. 익스텐트 디렉터는 Oracle 분할의 컨텍스트에서 배포되는 글로벌 서비스 관리자입니다. 고가용성을 위해 익스텐트가 있는 각 가용성 영역에 하나 이상의 익스텐트 디렉터를 배포하는 것이 좋습니다.
데이터베이스에 처음으로 연결하면 익스텐트 디렉터가 라우팅 정보를 설정하고 후속 요청에 대한 정보를 캐시합니다. 해당 정보는 익스텐트 디렉터를 우회합니다. 익스텐트와 세션이 설정되면 모든 SQL 쿼리와 DML이 지원되고 지정된 익스텐트 범위에서 실행됩니다. 이 라우팅은 속도가 빠르며 인트라 익스텐트 트랜잭션을 수행하는 모든 OLTP 워크로드에 사용됩니다. 최고 수준의 성능과 가용성이 필요한 모든 OLTP 워크로드에는 직접 라우팅을 사용하는 것이 좋습니다. 익스텐트를 사용할 수 없게 되거나 분할 토폴로지가 변경되면 라우팅 캐시가 자동으로 새로 고침됩니다.
고성능 데이터 종속 라우팅의 경우 Oracle에서는 분할된 데이터베이스의 데이터에 액세스할 때 연결 풀을 사용할 것을 권장합니다. Oracle 연결 풀, 언어별 라이브러리 및 드라이버는 Oracle 분할을 지원합니다. 자세한 내용은 Oracle 분할 개요의 다음 항목을 참조하세요.
글로벌 서비스. 글로벌 서비스는 일반 데이터베이스 서비스와 비슷합니다. 글로벌 서비스는 데이터베이스 서비스의 모든 속성 외에도 분할된 데이터베이스에 대한 속성을 갖고 있습니다. 이러한 속성 중에는 클라이언트와 익스텐트 간의 지역 선호도 및 복제 지연 허용 오차도 있습니다. 분할된 데이터베이스에서 데이터를 읽고 쓰는 글로벌 서비스는 하나만 만들어야 합니다. Active Data Guard를 사용하고 익스텐트의 읽기 전용 복제본을 설정하는 경우 읽기 전용 워크로드에 사용할 또 다른 글로벌 서비스를 만들 수 있습니다. 클라이언트는 이러한 글로벌 서비스를 사용하여 데이터베이스에 연결할 수 있습니다.
익스텐트 데이터베이스. 익스텐트 데이터베이스는 Oracle 데이터베이스입니다. 각 데이터베이스는 FSFO가 설정된 Broker 구성에서 Oracle Data Guard를 사용하여 복제됩니다. 각 익스텐트에서 Data Guard 장애 조치(failover) 및 복제를 설정할 필요가 없습니다. 이러한 설정은 공유 데이터베이스를 만들 때 자동으로 구성되고 배포됩니다. 특정 익스텐트에 오류가 발생하면 Oracle Sharing이 데이터베이스 연결을 주 데이터베이스에서 대기 데이터베이스로 장애 조치(failover)합니다.
두 가지 인터페이스, 즉, Oracle Enterprise Manager 클라우드 제어 GUI 및 명령줄 유틸리티 GDSCTL
을 사용하여 Oracle 분할된 데이터베이스를 배포하고 관리할 수 있습니다. 클라우드 제어를 사용하여 여러 익스텐트의 가용성 및 성능을 모니터링할 수도 있습니다. GDSCTL DEPLOY
명령은 자동으로 익스텐트 및 해당 수신기를 만듭니다. 또한 이 명령은 관리자가 지정한 익스텐트 수준 고가용성에 사용되는 복제 구성을 자동으로 배포합니다.
데이터베이스를 분할하는 여러 가지 방법이 있습니다.
- 시스템 관리형 분할: 분할을 사용하여 자동으로 익스텐트 간에 분산
- 사용자 정의 분할: 데이터의 익스텐트 매핑을 지정할 수 있습니다. 규정 또는 데이터 지역화 요구 사항이 있는 경우에 적합합니다.
- 복합 분할: 여러 shardspace에 사용되는 시스템 관리형 분할과 사용자 정의 분할의 조합입니다.
- 테이블 하위 파티션: 일반적인 분할된 테이블과 유사합니다.
자세한 내용은 분할 방법을 참조하세요.
분할된 데이터베이스는 애플리케이션과 개발자의 눈에 단일 데이터베이스처럼 보입니다. 분할된 데이터베이스로 마이그레이션하는 경우 신중하게 계획을 수립하여 중복된 테이블과 분할된 테이블을 정확히 파악해야 합니다.
중복 테이블은 모든 익스텐트에 저장되고, 분할된 테이블은 여러 익스텐트에 분산됩니다. 작은 차원 테이블은 복제하고 팩트 테이블은 분산/분할하는 것이 좋습니다. 익스텐트 카탈로그를 중앙 코디네이터로 사용하거나 각 익스텐트에서 데이터 펌프를 실행하여 분할된 데이터베이스에 데이터를 로드할 수 있습니다. 자세한 내용은 분할된 데이터베이스로 데이터 마이그레이션을 참조하세요.
Data Guard를 사용하는 Oracle 분할
Oracle Data Guard는 시스템 관리형 분할, 사용자 정의 분할 및 복합 분할 방법을 이용하는 분할에 사용할 수 있습니다.
다음 다이어그램은 각 익스텐트의 고가용성을 위해 Oracle Data Guard를 사용하는 Oracle 분할의 참조 아키텍처입니다. 이 아키텍처 다이어그램은 복합 분할 방법을 보여줍니다. 이 아키텍처 다이어그램은 데이터 위치, 부하 분산, 고가용성 및 재해 복구에 대한 요구 사항이 다른 애플리케이션과 다를 수 있습니다. 애플리케이션에서 다른 분할 방법을 사용할 수 있습니다. Oracle 분할을 사용하면 이러한 요구 사항을 충족할 수 있으며 이러한 옵션을 제공하여 수평적으로, 효율적으로 스케일링할 수 있습니다. Oracle GoldenGate를 사용하여 유사한 아키텍처를 배포할 수도 있습니다.
시스템 관리형 분할은 구성 및 관리가 가장 쉽습니다. 사용자 정의 분할 또는 복합 분할은 데이터 및 애플리케이션이 지리적으로 분산되어 있거나 각 익스텐트의 복제본을 제어해야 하는 시나리오에 적합합니다.
위의 아키텍처에서 복합 분할은 데이터를 지리적으로 분산하고 애플리케이션 계층을 수평적으로 스케일 아웃하는 데 사용됩니다. 복합 분할은 시스템 관리형 분할과 사용자 정의 분할의 조합이므로 두 방법의 이점을 모두 제공합니다. 위의 시나리오에서 가장 먼저 데이터가 지역별로 구분된 여러 shardspaces에 분할됩니다. 그런 다음, 데이터가 일관된 해시를 사용하여 shardspace의 여러 익스텐트에 추가로 분할됩니다.
각 shardspace에는 여러 shardgroup이 포함됩니다. 각 shardgroup에는 여러 익스텐트가 있으며 shardgroup은 복제의 단위입니다. 각 shardgroup에는 shardspace의 모든 데이터가 포함됩니다. shardgroup A1 및 B1은 주 shardgroup이고, shardgroup A2 및 B2는 보조 shardgroup입니다. shardgroup이 아닌 개별 익스텐트를 복제 단위로 선택할 수 있습니다.
위의 아키텍처에서 GSM(Global Service Manager)/익스텐트 디렉터는 고가용성을 위해 모든 가용성 영역에 배포됩니다. 데이터 센터/지역마다 하나 이상의 GSM/익스텐트 디렉터를 배포하는 것이 좋습니다. 또한 애플리케이션 서버 인스턴스는 shardgroup를 포함하고 있는 모든 가용성 영역에 배포됩니다. 이렇게 설정하면 애플리케이션이 애플리케이션 서버와 데이터베이스/shardgroup 간의 대기 시간을 짧게 유지할 수 있습니다. 데이터베이스에 오류가 발생하는 경우 데이터베이스 역할이 전환되면 대기 데이터베이스와 동일한 영역에 있는 애플리케이션 서버에서 요청을 처리할 수 있습니다. Azure Application Gateway와 익스텐트 디렉터는 요청 및 응답 대기 시간을 추적하면서 그에 맞게 요청을 라우팅합니다.
애플리케이션 관점에서 클라이언트 시스템은 클라이언트와 가장 가까운 지역으로 요청을 리디렉션하는 Azure Application Gateway 또는 Azure의 다른 부하 분산 기술에 요청을 보냅니다. Azure Application Gateway는 고정 세션도 지원하므로 동일한 클라이언트에서 들어오는 모든 요청은 동일한 애플리케이션 서버로 라우팅됩니다. 애플리케이션 서버는 데이터 액세스 드라이버의 연결 풀링을 사용합니다. 이 기능은 JDBC, ODP.NET, OCI 등의 드라이버에서 사용할 수 있습니다. 이러한 드라이버는 요청의 일부로 지정된 분할 키를 인식할 수 있습니다. JDBC 클라이언트용 Oracle UCP(Universal Connection Pool)는 Apache Tomcat이나 IIS 같은 비 Oracle 애플리케이션 클라이언트를 사용하도록 설정하여 Oracle 분할 작업을 수행할 수 있습니다. 자세한 내용은 데이터베이스 분할을 위한 UCP 공유 풀 개요를 참조하세요.
초기 요청 중에 애플리케이션 서버는 해당 지역의 익스텐트 디렉터에 연결하여 요청을 라우팅해야 하는 익스텐트의 라우팅 정보를 가져옵니다. 전달된 분할 키에 따라 디렉터는 애플리케이션 서버를 해당하는 익스텐트에 라우팅합니다. 애플리케이션 서버는 맵을 작성하여 이 정보를 캐시하고, 후속 요청에서 익스텐트 디렉터를 우회하여 요청을 익스텐트에 직접 라우팅합니다.
GoldenGate를 사용하는 Oracle 분할
다음 다이어그램은 각 익스텐트의 지역 내 고가용성을 위해 Oracle GoldenGate를 사용하는 Oracle 분할의 참조 아키텍처입니다. 위의 아키텍처와는 반대로 이 아키텍처는 여러 가용성 영역이 있는 단일 Azure 지역 내의 고가용성만 보여줍니다. 이전 예제와 비슷하게 Oracle GoldenGate를 사용하여 다중 지역 고가용성 분할된 데이터베이스를 배포할 수 있습니다.
위의 참조 아키텍처에서는 시스템 관리형 분할 방법을 사용하여 데이터를 분할합니다. Oracle GoldenGate 복제는 청크 수준에서 수행되므로 한 익스텐트에 복제된 데이터의 절반을 다른 익스텐트에 복제할 수 있습니다. 나머지 절반은 다른 익스텐트에 복제할 수 있습니다.
데이터가 복제되는 방식은 복제 인수에 따라 달라집니다. 복제 인수가 2인 경우 shardgroup의 3개 익스텐트에 각 데이터 청크의 복사본 2개가 만들어집니다. 마찬가지로 복제 인수가 3이고 shardgroup에 익스텐트가 3개 있는 경우에는 각 익스텐트의 모든 데이터가 shardgroup의 다른 모든 익스텐트에 복제됩니다. shardgroup에 있는 각 익스텐트의 복제 인수가 서로 다를 수 있습니다. 이 설정은 shardgroup 내부와 여러 shardgroup에서 효율적으로 고가용성 및 재해 복구 디자인을 정의하는 데 도움이 됩니다.
위의 아키텍처에서 shardgroup A와 shardgroup B는 동일한 데이터를 포함하고 있지만 서로 다른 가용성 영역에 있습니다. shardgroup A와 shardgroup B의 복제 인수가 똑같이 3인 경우 분할된 테이블의 각 행/청크가 두 shardgroup에서 6회 복제됩니다. shardgroup A의 복제 인수가 3이고 shardgroup B의 복제 인수가 2인 경우에는 각 행/청크가 두 shardgroup에서 5회 복제됩니다.
이 설정은 인스턴스 수준 또는 가용성 영역 수준 오류가 발생할 때 데이터 손실을 방지합니다. 애플리케이션 계층은 각 익스텐트에서 읽고 쓸 수 있습니다. 충돌을 최소화하기 위해 Oracle 분할에서는 해시 값의 각 범위에 대한 마스터 청크를 지정합니다. 이 기능은 특정 청크에 대한 쓰기 요청이 해당 청크로 전달되도록 보장합니다. 또한 Oracle GoldenGate는 발생하는 충돌을 처리할 수 있도록 자동 충돌 감지 및 해결 기능을 제공합니다. Oracle Sharding을 사용하여 GoldenGate를 구현하는 방법과 제한 사항에 대한 자세한 내용은 분할된 데이터베이스에서 Oracle GoldenGate 사용을 참조하세요.
위의 아키텍처에서 GSM/익스텐트 디렉터는 고가용성을 위해 모든 가용성 영역에 배포됩니다. 데이터 센터 또는 지역마다 하나 이상의 GSM/익스텐트 디렉터를 배포하는 것이 좋습니다. 애플리케이션 서버 인스턴스는 shardgroup를 포함하고 있는 모든 가용성 영역에 배포됩니다. 이렇게 설정하면 애플리케이션이 애플리케이션 서버와 데이터베이스/shardgroup 간의 대기 시간을 짧게 유지할 수 있습니다. 데이터베이스에 오류가 발생하는 경우 데이터베이스 역할이 전환되면 대기 데이터베이스와 동일한 영역에 있는 애플리케이션 서버에서 요청을 처리할 수 있습니다. Azure Application Gateway와 익스텐트 디렉터는 요청 및 응답 대기 시간을 추적하면서 그에 맞게 요청을 라우팅합니다.
애플리케이션 관점에서 클라이언트 시스템은 클라이언트와 가장 가까운 지역으로 요청을 리디렉션하는 Azure Application Gateway 또는 Azure의 다른 부하 분산 기술에 요청을 보냅니다. Azure Application Gateway는 고정 세션도 지원하므로 동일한 클라이언트에서 들어오는 모든 요청은 동일한 애플리케이션 서버로 라우팅됩니다. 애플리케이션 서버는 데이터 액세스 드라이버의 연결 풀링을 사용합니다. 이 기능은 JDBC, ODP.NET, OCI 등의 드라이버에서 사용할 수 있습니다. 이러한 드라이버는 요청의 일부로 지정된 분할 키를 인식할 수 있습니다. JDBC 클라이언트용 Oracle UCP(Universal Connection Pool)는 Apache Tomcat이나 IIS 같은 비 Oracle 애플리케이션 클라이언트를 사용하도록 설정하여 Oracle 분할 작업을 수행할 수 있습니다.
초기 요청 중에 애플리케이션 서버는 해당 지역의 익스텐트 디렉터에 연결하여 요청을 라우팅해야 하는 익스텐트의 라우팅 정보를 가져옵니다. 전달된 분할 키에 따라 디렉터는 애플리케이션 서버를 해당하는 익스텐트에 라우팅합니다. 애플리케이션 서버는 맵을 작성하여 이 정보를 캐시하고, 후속 요청에서 익스텐트 디렉터를 우회하여 요청을 익스텐트에 직접 라우팅합니다.
패치 및 유지 관리
Oracle 워크로드를 Azure에 배포하면 모든 호스트 운영 체제 수준 패치를 Microsoft에서 처리합니다. Microsoft는 계획된 운영 체제 수준 유지 관리를 고객에게 미리 고지합니다. 서로 다른 두 가용성 영역의 두 서버가 동시에 패치되는 일은 절대 없습니다. VM 유지 관리 및 패치에 대한 자세한 내용은 Azure Virtual Machines의 가용성 옵션을 참조하세요.
Azure Automation 업데이트 관리를 사용하여 가상 머신 운영 체제 패치를 자동화할 수 있습니다. Azure Pipelines 또는 Azure Automation 업데이트 관리를 사용하여 Oracle 데이터베이스의 패치 및 유지 관리를 자동화하고 예약하면 가동 중지 시간을 최소화할 수 있습니다. 지속적인 업데이트 및 청록색 배포에 대한 자세한 내용은 점진적 노출 기술을 참조하세요.
아키텍처 및 디자인 고려 사항
- 라이선스 비용을 절감하고 성능을 최대화하기 위해 제약이 있는 코어 vCPU가 포함된 하이퍼스레드 메모리 최적화 가상 머신을 Oracle Database VM에 사용하는 것이 좋습니다. 성능과 고가용성을 위해 여러 프리미엄 또는 울트라 디스크(관리 디스크)를 사용합니다.
- 관리 디스크를 사용하는 경우 다시 시작할 때 디스크/디바이스 이름이 변경될 수 있습니다. 다시 시작해도 탑재가 유지되도록 이름 대신 디바이스 UUID를 사용하는 것이 좋습니다. 자세한 내용은 /etc/fstab에 새 파일 시스템 추가를 참조하세요.
- 가용성 영역을 사용하여 지역 내 고가용성을 구현합니다.
- 가능하다면 Oracle 데이터베이스에 울트라 디스크 또는 프리미엄 디스크를 사용하는 것이 좋습니다.
- Oracle Data Guard를 사용하여 다른 Azure 지역에 대기 Oracle 데이터베이스를 설정하는 것이 좋습니다.
- 애플리케이션과 데이터베이스 계층 간의 대기 시간을 줄이기 위해 근접 배치 그룹을 사용하는 것이 좋습니다.
- Azure VM의 최대 네트워크 대역폭은(일반적으로) 동일한 SKU의 최대 디스크 처리량보다 높습니다. Azure NetApp Files와 같은 고성능, 짧은 대기 시간의 네트워크 스토리지를 사용하면 동일한 VM SKU에서 더 높은 처리량을 달성하거나 더 작은 VM SKU를 사용할 수 있습니다. 데이터베이스용.
- 관리, 모니터링 및 로깅을 위해 Oracle Enterprise Manager를 설정합니다.
- 데이터베이스의 스토리지 관리를 간소화하기 위해 Oracle Automatic Storage Management를 사용하는 것이 좋습니다.
- Oracle Data Guard 소개
- 애플리케이션 코드를 수정하여 애플리케이션의 복원력 향상에 도움이 될 수 있는 클라우드 네이티브 패턴을 추가합니다. 재시도 패턴, 회로 차단기 패턴, 클라우드 디자인 패턴 가이드에 정의된 기타 패턴을 고려합니다.
다음 단계
시나리오에 적용되는 다음 Oracle 참조 문서를 검토합니다.