Amazon Web Services ブログ

Amazon EBS gp3 ボリュームで Amazon OpenSearch Service のストレージコストを削減する

本記事は 2022 年 11 月 23 日 に公開された「Lower your Amazon OpenSearch Service storage cost with gp3 Amazon EBS volumes」を翻訳したものです。

Amazon OpenSearch Service を使用すると、インタラクティブなログ分析、リアルタイムアプリケーションモニタリング、ウェブサイト検索などを簡単に実行できます。OpenSearch は、分散検索および分析エンジンである OpenSearch と、UI および可視化ツールである OpenSearch Dashboards で構成されるオープンソースの分散検索および分析スイートです。Amazon OpenSearch Service を使用する場合、インデックスを保存しクエリを処理するデータノードのセットを設定します。このサービスは、さまざまなストレージオプションを持つデータノード用のインスタンスタイプをサポートしています。R6GD や I3 などの一部のサポートされている Amazon Elastic Compute Cloud (Amazon EC2) インスタンスタイプには、ローカル NVMe ディスクがあります。その他のインスタンスタイプは Amazon Elastic Block Store (Amazon EBS) ストレージを使用します。

2022 年 7 月、OpenSearch Service は次世代の汎用 SSD (gp3) EBS ボリュームのサポートを開始しました。OpenSearch Service のデータノードは、高速なインデックス作成とクエリを提供するために、低レイテンシーで高スループットのストレージを必要とします。gp3 EBS ボリュームを使用すると、以前提供されていた gp2 EBS ボリュームタイプよりも 9.6% 低いコストで、より高いベースラインパフォーマンス (IOPS とスループット) を得られます。gp3 を使用すると、ボリュームサイズとは独立して追加の IOPS とスループットをプロビジョニングできます。gp3 ボリュームはバーストクレジットを使用しないため、より安定しています。gp3 ボリュームの OpenSearch サポートには、データノードあたりのボリュームサイズ制限の 2 倍化も含まれています。これらのより大きなボリュームにより、パッシブデータのコストを削減し、ノードあたりのストレージ量を増やすことができます。

価格/パフォーマンスと柔軟性の面で、gp3 を最適な Amazon EBS オプションとして検討することをお勧めします。この記事では、gp3 の基本とさまざまなコスト削減のユースケースについて説明します。以前の世代のストレージ (gp2、PIOPS、マグネティック) ボリュームから最新世代の gp3 ボリュームに移行することで、月額ストレージコストを削減し、インスタンス使用率を最適化できます。

gp2 と gp3 の比較

gp3 は汎用 SSD gp2 ボリュームの後継です。gp3 の主な利点には、より高いベースラインパフォーマンス、9.6% 低いコスト、ボリュームに関係なくより高いパフォーマンスをプロビジョニングできる機能があります。次の表は、gp2 と gp3 の主な違いをまとめたものです。

ボリュームタイプ gp3 gp2
ボリュームサイズ インスタンスタイプによって異なります。OpenSearch Service がサポートする最大は R6g.12Xlarge で 24 TiB です。最新のインスタンス制限については、Amazon OpenSearch Service のクォータを参照してください。 インスタンスタイプによって異なります。OpenSearch Service がサポートする最大は R6g.12Xlarge で 12 TiB です。
ベースライン IOPS 1,024 GiB までのボリュームサイズで 3,000 IOPS。1,024 GiB を超えるボリュームでは、バーストクレジットの複雑さなしに 3 IOPS/GiB を得られます。 3 IOPS/GiB (最小 100 IOPS) で最大 16,000 IOPS。1 TiB 未満のボリュームは最大 3,000 IOPS までバーストすることもできます。
最大 IOPS/ボリューム 16,000 16,000
ベースラインスループット 170 GiB までのボリュームサイズで 125 MiB/s が無料、170 GiB を超えるボリュームで 250 MiB/s が無料。 ボリュームサイズに応じて 125 MiB/s から 250 MiB/s の間。
最大スループット/ボリューム 1,000 MiB/s 250 MiB/s
us-east-1 リージョンの料金
  • ストレージ – $0.122/GB-月。
  • IOPS – 1,024 GiB までのボリュームで 3,000 IOPS が無料、または 1,024 GiB を超えるボリュームで 3 IOPS/GiB が無料。無料制限を超えた場合、プロビジョニングされた IOPS あたり $0.008/月。
  • スループット – 170 GiB までのボリュームで 125 MiB/s が無料、または 170 GiB を超えるボリュームで 3 TiB ごとに +250 MiB/s が無料。無料制限を超えた場合、プロビジョニングされた MiB/s あたり $0.064/月。
  • ストレージ – $0.135/GB-月。
  • IOPS とスループットのプロビジョニングは許可されていません。
サポートされるインスタンス T3、C5、M5、R5、C6g、M6g、R6g T2、C4、M4、R4、T3、C5、M5、R5、C6g、M6g、R6g

gp3 で月額料金を削減する

ボリュームサイズとは独立して IOPS とスループットをプロビジョニングできる機能と、より高密度 (2 倍の大きさ) のボリュームサイズのサポートは、gp3 採用の 2 つの大きな利点です。これらの利点を組み合わせることで、月額料金を削減するための複数のユースケースが可能になります。このセクションでは、OpenSearch ドメインの料金比較の例をいくつか紹介します。

gp2 vs. gp3

これは最も一般的なシナリオで、既存の gp2 のお客様が gp3 に切り替えると、gp3 ストレージの GB あたりの月額料金が低いため、すぐに 9.6% の節約を開始できます。また、gp3 は R5、R6g、M5、M6g インスタンスファミリーで 2 倍大きいボリュームサイズをサポートしているという事実からも恩恵を受けることができます。これは、より高密度のストレージ要件のために新しいインスタンスを起動する必要がなく、同じインスタンスでより多くのストレージを実現できることを意味します。OpenSearch Service は現在、R6g.12Xlarge インスタンスで最大 24 TiB の gp3 ストレージをサポートしています。

PIOPS (io1) vs. gp3

OpenSearch Service は PIOPS SSD (io1) EBS ボリュームタイプをサポートしています。gp3 に切り替えて、特定のパフォーマンス要件を満たすために追加の IOPS とスループットをプロビジョニングできます。次の表は、6 TiB のストレージ要件と 16000 IOPS を持つ R5.large.search インスタンスの PIOPS (io1) と gp3 ストレージの月額コストを比較しています。この例では、gp3 の採用により 65% 節約できます。

. PIOPS (io1) gp3
インスタンスコスト

6 インスタンス * $0.186/時間 = $830/月

(r5.large.search は io1 で最大 1 TiB のストレージをサポートできます。6 TiB をサポートするには 6 つのインスタンスが必要です。)

3 インスタンス * $0.167/時間 = $372/月

(r6g.large.search は gp3 で最大 2 TiB のストレージをサポートできます。6 TiB をサポートするには 3 つのインスタンスが必要です。)

ストレージコスト (6 TiB)

6,597 GB * $0.169/GB-月 = $1115/月

注:

(a) PIOPS(io1) の料金は $0.169/GB/月です。

(b) 6TiB = 6597 GB

6,597 GB * $0.122/GB-月 = $805/月

注:

(a) gp3 ストレージの料金は $0.122/GB/月です。

(b) 6TiB = 6597 GB

PIOPS コスト (16000 PIOPS)

16000 IOPS * $0.088/IOPS-月 = $1408/月

注: io1 PIOPS レートは $0.088/IOPS-月です。

6 TiB ボリュームの gp3 には 18,000 IOPS が含まれているため、追加料金は不要です。

注: 3 IOPS/GiB のストレージ IOPS が料金に含まれています。

月額合計 $3,353/月 $1,177/月

I3 vs. gp3

I3 インスタンスには、低レイテンシー、非常に高いランダム I/O パフォーマンス、高いシーケンシャル読み取りスループットに最適化された Non-Volatile Memory Express (NVMe) SSD ベースのインスタンスストレージが含まれており、高い IOPS を提供します。ただし、I3 は古い第 3 世代の CPU を使用しており、サポートされる最大ストレージサイズは i3.16xlarge.search インスタンスで 15 TiB です。I3 インスタンスよりも低コストで優れたパフォーマンスを得るために、gp3 ストレージを備えた R6g などの最新世代のインスタンスの使用を検討する必要があります。

コスト上の利点を理解するために、12 TiB のデータストレージニーズに対して I3 と gp3 を比較してみましょう。次の表の計算によると、gp3 と現行世代のインスタンスに切り替えることで、月額料金を 56% 削減できます。

. I3.4xlarge gp3 with R6g.xlarge
us-east-1 リージョンのオンデマンドインスタンスコスト

4 インスタンス * $1.99/時間 = $5,922/月

注: I3.4xlarge.search は最大 3.8 TiB をサポートするため、12 TiB のストレージを管理するには 4 つのインスタンスが必要です。インスタンスコストは $1.99/時間です。

4 インスタンス * $0.335/時間 = $996/月

注: R6g.xlarge.search は gp3 で最大 3 TiB をサポートするため、12 TiB を管理するには 4 つのインスタンスが必要です。インスタンスコストは $0.335/時間です。

ストレージコスト (12 TiB) N/A (インスタンス料金に含まれています)

13,194 GB * $0.122/GB-月 = $1,610/月

注:

(a) 12 TiB = 13,194 GB

(b) ストレージコストは $0.122/GB/月

月額合計 $5,922/月 $2,606/月

UltraWarm vs. gp3

UltraWarm は、30 日以上経過したログなど、アクセス頻度の低いデータへの安価なアクセスを提供するように設計されています。ウォームストレージは、アクティブに書き込まれておらず、クエリ頻度が低く、高いパフォーマンスを必要としないインデックスに役立ちます。大規模でクエリ集約型のワークロードがあり、コストを最適化するために UltraWarm を使用しようとしているが、処理できる以上のクエリボリュームに遭遇している場合は、データボリュームの一部を gp3 ストレージを備えたホットノードに移動することを検討する必要があります。UltraWarm は、ウォームデータ (アクセス頻度の低いデータ) タイプのユースケースでは引き続き最も安価なオプションですが、ホットデータのユースケースには使用しないでください。低コストの gp3 ストレージと高密度インスタンスの組み合わせにより、ホットデータのコスト最適化された高パフォーマンスを実現できます。

次の表は、30 TiB の UltraWarm ワークロードを実行するための月額コストと、gp2 および gp3 の潜在的な月額コストとの比較を示しています。gp3 を使用すると、gp2 と比較して最大 36% 節約できます。UltraWarm のセットアップにはホットデータノードが必要ですが、gp2 と gp3 を使用したホットデータノードでの UltraWarm 置換コストに焦点を当てるため、UltraWarm 列ではそれらを除外しています。

. UltraWarm All Hot (gp2 with R6g.8xlarge) All Hot (gp3 with R6g.8xlarge)
インスタンスコスト (オンデマンド)

2 UW large インスタンス * $2.68/時間 = $3,987/月

注: ultrawarm1.large.search は最大 20 TiB をサポートするため、2 つのインスタンスが必要です。

4 インスタンス * $2.677/時間 = $7,966/月

注: r6g.8xlarge.search は gp2 で最大 8 TiB をサポートするため、4 つのインスタンスが必要です。

2 インスタンス * $2.677/時間 = $3,984/月

注: r6g.8xlarge.search は gp3 で最大 16 TiB をサポートするため、2 つのインスタンスのみが必要です。

ストレージコスト (30 TiB)

32,985 GB * $0.024/GB-月 = $792/月

注:

(1) ストレージ料金は $0.024/GB/月です。

(2) 30 TiB = 32985 GB

32,985 GB * $0.135/GB-月 = $4,453/月

注:

(1) ストレージ料金は $0.135/GB/月です。

(2) 30 TiB = 32985 GB

32,985 GB * $0.122/GB-月 = $4,024/月

注:

(1) ストレージ料金は $0.122/GB/月です。

(2) 30 TiB = 32985 GB

月額合計 $4,779/月 $12,419/月 $8,008/月

上記のすべてのユースケースはコストの観点からのものです。本番環境に変更を加える前に、独自のワークロードに対してテスト環境でパフォーマンスを検証し、設定変更がパフォーマンスの低下につながらないことを確認することをお勧めします。

gp3 の高密度ストレージでインスタンスコストを最適化する

OpenSearch Service は、gp3 のベースラインパフォーマンスの向上により、R5、R6g、M5、M6g インスタンスファミリーで gp2 と比較してインスタンスあたりのサポートされる最大ボリュームサイズを 100% 増加させました。インスタンスあたりのストレージ増加を活用することで、インスタンスのニーズを最適化できます。例えば、R6g.large は gp3 で最大 2 TiB をサポートしますが、gp2 では 1 TiB のみです。12 TiB のデータストレージのサポートが必要な場合、インスタンスコストを削減するために、ドメインを 6 つのデータノードから 3 つの R6g.large に再構成できます。OpenSearch EBS インスタンス固有のボリューム制限については、EBS ボリュームサイズのクォータを参照してください。

gp2 から gp3 へのアップグレード

EBS gp3 ボリュームタイプを使用するには、いくつかの手順を実行する必要があります。まず、ドメインのインスタンスが gp3 をサポートしていない場合は、サポートされているインスタンスタイプにアップグレードする必要があります。OpenSearch Service でサポートされているインスタンスのリストについては、EBS ボリュームサイズのクォータを参照してください。次に、マスターインスタンスノードのサイズ、シャードの数、ノードあたりのシャードのサイズの観点からクラスターを適切にサイジングする必要があります。詳細については、OpenSearch のベストプラクティスを参照してください。第三に、gp2 から gp3 への移行は簡単ですが、インスタンスサイズとボリュームの変更により一時的な停止が発生する可能性があるため、通常の変更管理メンテナンスウィンドウの一部として調整する必要があります。OpenSearch Service コンソールまたは UpdatedomainConfig API を使用して、gp2、マグネティック、PIOS (io1) などの既存の EBS ボリュームタイプから gp3 にドメイン設定をアップグレードできます。これらの設定変更により Blue/Green デプロイメントが開始され、バックグラウンドで実行されます。オンライントラフィックに影響を与える可能性があり、データサイズによっては数時間以内に完了します。

gp3 のベースラインパフォーマンスと追加プロビジョニング制限

gp3 の主要な機能の 1 つは、ボリュームとは独立して IOPS とスループットをスケーリングできることです。アプリケーションがより多くのパフォーマンスを必要とする場合、追加料金で最大 16,000 IOPS と 1,000 MiB/s のスループットにスケールアップできます。OpenSearch Service EBS gp3 は、任意のボリュームサイズで 3,000 IOPS と 125 MiB/s のスループットのベースラインパフォーマンスを提供します。さらに、OpenSearch Service は最適なパフォーマンスを確保するために、より大きなボリュームに追加の IOPS とスループットをプロビジョニングします。1,024 GiB を超えるボリュームでは 3 IOPS/GiB を受け取り、170 GiB を超えるボリュームでは 3 TiB のストレージごとに 250 MiB/s の増分を得られます。

次の表は、OpenSearch Service のベースライン IOPS とスループット、およびプロビジョニングできる最大量を示しています。インスタンスタイプには、24 時間の期間でこれらのパフォーマンスベースラインをどの程度、どのくらいの期間サポートできるかに関する追加の制限がある場合があることに注意してください。インスタンスとその制限の詳細については、Amazon EBS 最適化インスタンスを参照してください。

お客様がプロビジョニングできる追加パフォーマンス

.. ベースライン (ストレージ料金に含まれる) お客様がプロビジョニングできる追加パフォーマンス
ボリュームストレージ (GiB) IOPS スループット (MiB/s) IOPS スループット (MiB/s)
170 3,000 125 13,000 875
172 3,000 250 13,000 750
1,024 3,000 250 13,000 750
1,025 3,075 250 12,925 750
3,000 9,000 250 7,000 750
3,073 9,219 500 6,781 500
6,000 18,000 500 NA 500
6,145 18,435 750 NA 250
9,001 27,003 1,000 NA NA
24,000 72,000 2,000 NA NA

追加パフォーマンスは必要ですか?

ほとんどのユースケースでは、追加の IOPS とスループットをプロビジョニングする必要はなく、gp3 のベースラインパフォーマンスで十分です。Amazon CloudWatch メトリクスを使用して使用パターンを確認し、現在の IOPS とスループットの制限がインデックスとクエリのパフォーマンスのボトルネックになっていることが観察された場合は、追加のパフォーマンスをプロビジョニングする必要があります。詳細については、EBS ボリュームメトリクスを参照してください。

まとめ

この記事では、OpenSearch Service の汎用 SSD gp3 ボリュームが月額ストレージおよびインスタンスコストを大幅に削減し、gp2 ボリュームよりもコスト効率が高くなる方法について説明しました。gp2 と同じサイズとパフォーマンス設定で gp3 ボリュームに移行することが、コストを削減する最も迅速で簡単な方法です。さらに、gp3 のデータノードあたりの高密度ストレージのサポートを活用して、インスタンスコストの削減も検討する必要があります。

詳細については、Amazon OpenSearch Service の料金Amazon OpenSearch Service の設定 API リファレンスをご覧ください。


著者について

Siddhant GuptaSiddhant Gupta は、インドのハイデラバードを拠点とする Amazon Web Services のシニアテクニカルプロダクトマネージャーです。Siddhant は Amazon に 5 年以上在籍しており、現在は OpenSearch Service チームで新しいリージョンの立ち上げ、料金戦略、EC2 および EBS のイノベーションを OpenSearch Service のお客様に提供する業務に携わっています。分析と機械学習に情熱を持っています。余暇には、旅行、フィットネス活動、家族との時間、ノンフィクションの読書を楽しんでいます。


この記事は Kiro が翻訳を担当し、Solutions Architect の 榎本 貴之 がレビューしました。