☁️Cloud/AWS
RDS 란?
terranbin
2024. 3. 18. 14:04
728x90
SMALL
Relational Database Service 의 약자로, 관계형 데이터베이스이다.
AWS 상에서 사용할 수 있도록 지원하는 Database 서비스
생성 후 서비스를 이용하기만 되므로, SaaS 에 해당
MySQL, MariaDB, Postgre SQL, Oracle, MS SQL, Aurora 사용 가능
DB 인스턴스에 대한 SSH 액세스 불가 및 OS 제어 불가능 (AWS 가 관리하는 소위 Managed Service 임)
백업, 소프트웨어 패치, 장애 감지 및 복구는 AWS 가 관리
Storage 용량에 대하여 Auto Scaling 지원
- DB instance
- Instance: RDS 기본 구성 요소로서 클라우드에서 실행하는 격리된 데이터베이스 환경을 의미
- 인스턴스 내에서는 여러 사용자가 만든 데이터베이스가 포함되며, 액세스할 여러 도구와 앱 사용 가능
- MySQL, MariaDB, PostgreSQL, Oracle, Microsoft SQL Server, Amazon Aurora
- DB 인스턴스도 EC2 처럼 다양한 클래스를 가지고 있음
- RDS 도 클라우드에서 실행되기 때문에 하나의 AZ 에서 격리되어 인스턴스로서 실행
- DB Instance Storage
- Instance Storage: 데이터베이스 유지를 위해 EBS 를 사용하며, 필요한 스토리지 용량에 맞춰 자동으로 데이터를 여러 EBS 볼륨에 나누어 저장
- Storage 유형
- 범용 SSD: 대부분의 워크로드에서 사용하는 무난한 스토리지
- 프로비져닝 IOPS: 빠르고 일관적인 I/O 성능이 필요하고 일관적으로 낮은 지연시간이 요구될 경우 사용하는 스토리지
- 마그네틱: 접속 빈도가 적은 워크로드에 적합한 스토리
- Multi-AZ
- RDS 는 Multi-AZ 라는 기능을 통해 고가용성을 지원함
- 활성화한 상태에서 master db 인스턴스에 문제가 발생하면, 자동으로 다른 AZ 의 예비 복제본 (Standby) 로 전환하며, 서비스를 이어나감
- 한 개의 DNS 네임을 공유하여, 즉시 장애 조치가 가능하도록 구현
- 말 그대로 다수의 AZ 에 DB Instance 를 둠으로써, 하나 혹은 그 이상의 AZ 가 파괴되어 서비스가 불가능할 때를 대비함
- master db 인스턴스가 수행해야 할 작업 (백업, 스냅샷 생성) 등을 대신하여 수행함으로써, Master db 인스턴스의 부담을 줄임
- master db 인스턴스에서 스냅샷을 캡쳐한 후에 다른 AZ 에 복원하여 '동기식' 예비 복제본을 생성함
- active (AZ A) - standby (AZ B, C) 구조를 형성한 후, 지속적으로 동기화함
- '예비' 복제본이기 때문에 읽기 및 쓰기 작업을 수행할 수 없음
- Multi-AZ 를 사용하는 경우, 단일 AZ 배포에 비해 쓰기 및 저장 지연 시간이 길어질 수 있음
- 전환되는 상황
- 가용 영역 중단
- Master DB 인스턴스 오류
- DB 인스턴스 서버 유형 변경
- Master DB 인스턴스 OS 에서 소프트웨어 패치 실시
- 장애 조치 재부팅 (Failover) 실시
- Single-AZ 에서 Multi-AZ 로 전환 시, 중단시간 (Down Time) 은 없으나, 변환간 성능에 영향을 미칠 수 있음
- Multi-AZ 활성화 시, DB 인스턴스 생성 시 스냅샷이 자동 생성되고, 스냅샷을 기반으로 Standby DB 인스턴스를 생성하게 되며 이를 기반으로 동기식 복제를 수행
- Read Replica
- 읽기 작업만을 수행하는 DB 인스턴스의 읽기 전용 복제본
- RDS 로 들어오는 쿼리를 읽기 전용 복제본으로 우회시켜 Master DB 인스턴스의 부하를 줄일 수 있음
- 우선 Master DB 인스턴스의 스냅샷을 캡쳐한 후, 이를 기반으로 Read Replica 를 생성하며 데이터를 '비동기' 복제 방식을 통해 업데이트
- 읽기 전용 복제본이 Master db 인스턴스의 최신 데이터를 복제하기 전까지 지연 발생 가능성 내재
- MySQL, Oracle, PostgreSQL, Maria DB 에서 사용 가능
- 교차 리전 읽기 전용 복제본 포함 인스턴스당 최대 15개 생성 가능
- 읽기 복제본 또한 독립 실행형 인스턴스로 승격 가능
- 장애 대응을 위한 Multi-AZ 로 지정 가
LIST