はじめに
こんにちは、山田です。
現在携わっている案件で、Amazon Auroraを使用する機会があったため、Amazon Aurraについて学習しました。
今回学習したことを忘れないように、記事にまとめていきます。
Amazon Auroraとは
Amazon Auroraとは、クラウド向けにAWSが構築したデータベースです。
RDSを作成する際に、データベースエンジンの1つとしてAuroraを選択できます。
Auroraの特徴
Auroraの特徴としては、主に以下の点が挙げられます。
・Aurora DBクラスターは、1つ以上のDBインスタンスと、データを管理するクラスターボリュームで構成される。
・インスタンスとストレージとボリュームが分離している。
・読み込み処理およびフェイルオーバーが可能なAuroraレプリカが作成可能。
・データボリュームは、3AZに2個ずつ、計6個のコピーが作成され、高い障害性を持つ。
Auroraの可用性について
Auroraではストレージとインスタンス機能が分離しているため、クラスター上のインスタンスに障害が発生した場合もデータは安全に保持されます。
クラスターボリュームの可用性
Auroraの6個のコピーのうち、2つに障害が発生した場合は書き込み読み取りに影響はないです。
インスタンスの可用性
Auroraレプリカは通常のRDSのスタンバイインスタンスとリードレプリカの両方の役割を持ちます。
プライマリのインスタンスに障害が発生すると、Auroraレプリカがプライマリに昇格しフェイルオーバーします。
フェイルオーバーの時間に関しては、多くの場合は60秒未満とされています。
Auroraレプリカが複数個ある場合は、以下の優先度に従ってレプリカを昇格させます。
①指定した優先度が高い(0に近い)リードレプリカ
②優先度が同じ場合はサイズの大きいリードレプリカ
③優先度とサイズが同じ場合は任意のリードレプリカ
以下の場合だと、優先度1のインスタンスがプライマリに昇格します。
クラスターキャッシュ管理
クラスターキャッシュ機能を有効にすると、レプリカにキャッシュ情報が同期されるため、フェイルオーバー時のパフォーマンスの影響を最低限に抑えられます。
Auroraグローバルデータベース
通常、Auroraクラスターは単一リージョン内に構築しますが、複数のリージョンにまたがるグローバルデータベースを構築することもできます。
グローバルデータベースに関しては、以下の特徴があります。
・セカンダリリージョンは、読み込み専用となる。
・リージョン間のデータコピーはAuroraの機能で自動的に実行される。
・リージョン間のデータコピーは通常1秒未満で実行され、リージョン間のフェイルオーバーは通常1分未満で実行される。
Auroraマルチマスタークラスター
Auroraマルチマスタークラスターを使用すると、クラスター内のすべての複数のインスタンスは読み書き可能になります。
利用にあたっては、以下の制約があります。
・MySQLが対象
・インスタンス数は最大2つ
・インスタンスの停止不可
・通常のクラスターより書き込みパフォーマンスが落ちることがある
・バックトラック機能の利用不可
Auroraパフォーマンス
Auroraのパフォーマンスに関しては、通常RDSと共通する部分が多くあります。
RDSと異なる点について記載していきます。
ストレージ
Auroraのクラスターボリュームは、データ量に応じて自動的に増加し、最大128TBまで増やすことができます。
Auroraレプリカを使用してパフォーマンス向上
読み込み性能向上も目的で、Auroraレプリカを使用できます。
最大で15個作成することができます。
アクセス方法に関しては、以下の2種類が設定可能です。
①読み込みエンドポイント:読み込みエンドポイントを指定すると、各レプリカに分散したアクセスが可能
②カスタムエンドポイント:特定のインスタンスにアクセス可能
Aurora Serverless
Aurora Serverlessは、DBインスタンスのサイズ指定不要で、CPUやメモリなどのキャパシティを自動で管理してスケールアップ/ダウンしてくれます。
スケーリングに関しては、Auroraキャパシティユニット(ACU)と呼ばれる単位を増減することにより、自動スケーリングを実施しています。
ユースケースは以下の通りです。
・利用頻度の少ないアプリケーション
・利用頻度の増減が激しいアプリケーション
・夜間利用しない開発環境
Aurora監査機能
AuroraにはAdvancedAuditingという、監査機能が存在します。
ログのパラメータに関しては以下のものが存在します。
パラメータ | 内容 |
---|---|
CONNECT | ユーザー情報を含む接続の成功、失敗、切断の記録 |
QUERY | すべてのクエリの記録 |
QUERY_DCL | QUERYのうちGRANT、REVOKEなどのデータ制御言語に限定した記録 |
QUERY_DDL | QUERYのうちCREATE、ALTERなどのデータ定義言語に限定した記録 |
QUERY_DML | QUERYのうちINSERT、UPDATEなどのデータ操作言語に限定した記録 |
TABLE | クエリ実行の影響をうけたテーブルの記録 |
Auroraバックアップ
Auroraには、自動バックアップ機能があり、このバックアップは設定した保持期間、継続的かつ増分的に取得されます。
保持期間に関しては、1~35日で指定でき、S3に保存されます。
Auroraクローン
クローンでは、データストレージのコピーは行われず、インスタンス部分のみが行われるため、高速に同じデータを扱うクラスターを作成できます。
ソースまたはクローン先のクラスターでデータの書き込みがあると、新しいストレージが割り当てられます。よって多くの書き込みがある場合ではこのクローン機能は使用しません。
クローンは、別のAWSアカウント、別のVPCに共有することが可能です。ただし、VPCのサブネットは同じアベイラビリティゾーンである必要があります。
バックトラック
バックトラックは、Auroraの巻き戻し機能です。
バックトラックにより以下のような操作が可能になります
・直前で実行したDELETE処理などの取り消し
・直前の操作前に戻して、その時間でどのようなデータの変更があったかを調べる
バックトラック機能を有効にするには、ターゲットバックトラックウィンドゥという時間を設定する必要があります。
この時間はデータをどれほど前に戻せるかの時間です。
バックトラックに関しては、以下の制限があります。
・時間の上限は72時間
・バックトラックはクラスター作成時またはスナップショット復元時に有効にできる
・バックトラック処理中はDBインスタンスがわずかに中断する
・Aurora MySQLでのみ使用可能
障害挿入クエリ
AWSが管理するインスタンスやストレージのに障害は通常利用者が意図的に発生させてテストすることはできません。
このテストを可能にするのが障害挿入クエリです。以下の状況をシミュレートできます。
・DBインスタンスの障害
・Auroraレプリカの障害
・ディスク障害
・ディスク輻輳
DBインスタンスの障害を発生させる場合は、次のようなSQL文を実行します。
ALTER SYSTEM CRASH [INSTANCE or DISPATCHER or NODE]
#NODEはインスタンス、ディスパッチャーの両方が対象になります。
最後に
Amazon Auroraについて自分なりにまとめてみました。
Amazon Auroraに関しては、中々触れる機会がないので、今回記事にまとめることによって知識が深まった気がしてます。
今回記載した内容が、今後Auroraを使用する人の参考になればと思います。