外部で作成されたバックアップで新しいクラスタのシード - Amazon ElastiCache for Redis

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

外部で作成されたバックアップで新しいクラスタのシード

新しい Redis クラスターを作成するときに、Redis .rdb バックアップファイルのデータでシードできます。クラスターをシードすることは、現在 ElastiCache の外部で Redis インスタンスを管理していて、Redis クラスターの新しい ElastiCache に既存の Redis データを入力する場合に役に立ちます。

Amazon ElastiCache 内で作成された Redis バックアップから新しい Redis クラスターのシード値を設定する方法については、「オプションのクラスタサイズ変更によるバックアップからの復元」を参照してください。

新しい Redis .rdb ファイルを使用して新しい Redis クラスターをシードするときは、以下を実行できます。

  • パーティション分割されていないクラスターから、Redis バージョン 3.2.4 を実行している Redis (クラスターモードが有効) クラスターにアップグレードします。

  • 新しいクラスターのシャード (API および CLI ではノードグループと呼ばれる) の数を指定します。この数は、バックアップファイルの作成に使用されたクラスター内のシャードの数とは異なる場合があります。

  • 新しいクラスターに対して別のノードタイプを指定する—バックアップを作成したクラスタで使用されているものよりも大きいか小さいかを確認します。より小さいノードタイプにスケールダウンする場合は、新しいノードタイプに、データと Redis のオーバーヘッドに対する十分なメモリがあることを確認してください。詳細については、「Redis スナップショットを作成するのに十分なメモリがあることを確認する」を参照してください。

  • バックアップファイルの作成に使用されたクラスターとは異なる新しい Redis (クラスターモードが有効) クラスターのスロットで、キーを分散します。

注記

Redis (クラスターモードが無効) クラスターから作成された .rdb ファイルから Redis (クラスターモードが有効) クラスターをシードすることはできません。

重要
  • Redis バックアップデータがノードのリソースを超えていないことを確認する必要があります。たとえば、2.9 GB のメモリがある cache.m3.medium ノードに、5 GB の Redis データがある .rdb ファイルをアップロードすることはできません。

    バックアップが大きすぎる場合、クラスターのステータスは restore-failed になります。その場合は、クラスターを削除してやり直す必要があります。

    ノードの種類および仕様の一覧については、「」を参照してください。Redis ノードタイプ固有のパラメータおよびAmazon ElastiCache製品の特徴と詳細

  • Redis .rdb ファイルは、Amazon S3 サーバー側の暗号化 (SSE-S3) でのみ暗号化できます。詳細については、「サーバー側の暗号化を使用したデータの保護」を参照してください。

以下では、Redis クラスターを Redis 用の ElastiCache 外部から Redis 用の ElastiCache に移行する方法について説明します。

ステップ 1: Redis バックアップを作成する

Redis バックアップを作成して、Redis インスタンスの ElastiCache をシードするには

  1. 既存の Redis インスタンスに接続します。

  2. Redis BGSAVE オペレーションまたは SAVE オペレーションを実行してバックアップを作成します。.rdb ファイルの場所を書き留めておきます。

    BGSAVE は非同期処理であり、処理中も他のクライアントをブロックしません。詳細については、Redis ウェブサイトの「BGSAVE」を参照してください。

    SAVE が同期され、完了するまで他のプロセスがブロックされます。詳細については、Redis ウェブサイトの「SAVE」を参照してください。

バックアップの作成の詳細については、「」を参照してください。Redis 永続性Redis ウェブサイトをご覧ください。

ステップ 2: を作成するAmazon S3バケットとフォルダ

バックアップファイルを作成したら、Amazon S3 バケット内のフォルダにアップロードする必要があります。これを行うには、最初にそのバケット内に Amazon S3 バケットとフォルダが必要です。既に適切なアクセス許可を持つ Amazon S3 バケットフォルダがある場合は、「ステップ 3: バックアップをアップロードするAmazon S3」に進むことができます。

Amazon S3 バケットを作成するには

  1. AWS Management Consoleにサインインし、Amazon S3 コンソール (https://console.aws.amazon.com/s3/) を開きます。

  2. 「」を作成する手順に従って、Amazon S3のバケットバケットの作成()Amazon Simple Storage Service コンソールユーザーガイド

    Amazon S3 バケットの名前は DNS に準拠している必要があります。それ以外の場合、ElastiCache はバックアップファイルにアクセスできません。DNS 準拠のルールでは、次のようになります:

    • 名前は、3 ~ 63 文字以内にする必要があります。

    • また、名前は、1 つのラベルか、または複数のラベルをピリオド (.) でつなげて構成します。各ラベルには次の規則が適用されます。

      • 先頭の文字には小文字の英文字または数字を使います。

      • 末尾の文字には小文字の英文字または数字を使います。

      • 小文字、数字、ダッシュのみを含める必要があります。

    • 名前を IP アドレスの形式にすることはできません (例: 192.0.2.0)。

    私たちは、あなたが作成することを強くお勧めしますAmazon S3バケットを同じAWSリージョンを新しいElastiCacheRedis クラスターの場合。このアプローチにより、ElastiCache が Amazon S3 から .rdb ファイルを読み取る場合のデータ転送速度が最大限に速くなります。

    注記

    データを可能な限り安全に保つには、Amazon S3 バケットに対するアクセス許可をできるだけ制限します。同時に、バケットとその内容を使用して新しい Redis クラスターをシードするためのアクセス許可を付与する必要があります。

フォルダを Amazon S3 バケットに追加するには

  1. AWS Management Consoleにサインインし、Amazon S3 コンソール (https://console.aws.amazon.com/s3/) を開きます。

  2. .rdb ファイルのアップロード先となるバケットの名前を選択します。

  3. [Create folder] を選択します。

  4. 新しいフォルダの名前を入力します。

  5. [Save] を選択します。

    バケット名とフォルダ名の両方の名前を書き留めます。

ステップ 3: バックアップをアップロードするAmazon S3

次に、「ステップ 1: Redis バックアップを作成する」で作成した .rdb ファイルをアップロードします。アップロード先は、「ステップ 2: を作成するAmazon S3バケットとフォルダ」で作成した Amazon S3 バケットとフォルダです。このタスクの詳細については、「」を参照してください。バケットにオブジェクトを追加する。ステップ 2 と 3 の間に、作成したフォルダ名を選択します。

.rdb ファイルを Amazon S3 フォルダにアップロードするには

  1. AWS Management Consoleにサインインし、Amazon S3 コンソール (https://console.aws.amazon.com/s3/) を開きます。

  2. ステップ 2 で作成した Amazon S3 バケットの名前を選択します。

  3. ステップ 2 で作成したフォルダの名前を選択します。

  4. [Upload (アップロード)] を選択します。

  5. [Add files] を選択します。

  6. アップロードする 1 つまたは複数のファイルを参照して見つけ、そのファイルを選択します。複数のファイルを選択するには、Ctrl キーを押しながら各ファイル名を選択します。

  7. [Open (開く)] を選択します。

  8. 正しいファイルが [Upload] ダイアログボックスに表示されることを確認してから、[Upload] を選択します。

.rdb ファイルへのパスを記録します。たとえば、バケット名が myBucket で、パスが myFolder/redis.rdb の場合は、「myBucket/myFolder/redis.rdb」と入力します。新しいクラスターにこのバックアップのデータをシードする際にこのパスが必要です。

詳細については、「」を参照してください。バケットの制約と制限()Amazon Simple Storage Service 開発者ガイド

ステップ 4: 許可ElastiCache.rdb ファイルへの読み取りアクセスをに許可するには

ここで、.rdb バックアップファイルへの読み取りアクセス権を ElastiCache に付与します。許可するElastiCacheバケットファイルへのアクセス権は、バケットがデフォルトのAWSリージョンまたはオプトインインオプションAWSリージョン。

AWS2019 年 3 月 20 日より前に導入されたリージョンはデフォルトで有効になっています。これらの作業を開始できますAWSただちにリージョン。2019 年 3 月 20 日以降に導入された アジアパシフィック (香港) や 中東 (バーレーン) などのリージョンはデフォルトでは無効になっています。これらのリージョンを使用するには、有効にする必要があります。詳細については、管理AWSのリージョン()AWS-GEN-REF;

あなたのアプローチは、AWSサービス対象:

許可ElastiCacheデフォルトのリージョンの.rdb ファイルへの読み取りアクセス

AWS2019 年 3 月 20 日より前に導入されたリージョンはデフォルトで有効になっています。これらの作業を開始できますAWSただちにリージョン。2019 年 3 月 20 日以降に導入された アジアパシフィック (香港) や 中東 (バーレーン) などのリージョンはデフォルトでは無効になっています。これらのリージョンを使用するには、有効にする必要があります。詳細については、管理AWSのリージョン()AWS-GEN-REF;

許可するにはElastiCacheバックアップファイルへの読み込みアクセスをに許可するにはAWSリージョンはデフォルトで有効になる

  1. AWS Management Consoleにサインインし、Amazon S3 コンソール (https://console.aws.amazon.com/s3/) を開きます。

  2. .rdb ファイルを含む S3 バケットの名前を選択します。

  3. .rdb ファイルを含むフォルダの名前を選択します。

  4. .rdb バックアップファイルの名前を選択します。選択したファイルの名前は、ページ先頭のタブの上に表示されます。

    イメージ: S3 コンソールで選択されているファイル
  5. [Permissions (アクセス許可)] を選択します。

  6. aws-scs-s3-readonly または次のリストの正規化 ID の 1 つがユーザーとして表示されていない場合は、以下の作業を行います。

    1. []他のアクセスAWSアカウント] で、被付与者の追加

    2. ボックスに、AWS次に示すように、リージョンの正規 ID:

      • AWS GovCloud (US-West) リージョン:

        40fa568277ad703bd160f66ae4f83fc9dfdfd06c2f1b5060ca22442ac3ef8be6
        重要

        お客様がバックアップを AWS GovCloud (US) 内の Redis クラスターにダウンロードするには、そのバックアップが AWS GovCloud (US) 内の S3 バケットにあることが必要です。

      • AWSリージョンはデフォルトで有効になっています。

        540804c33a284a299d2547575ce1010f2312ef3da9b3a053c8bc45bf233e4353
    3. 以下について、[はい] を選択してバケットのアクセス許可を設定します。

      • オブジェクトの読み取り

      • オブジェクトの読み取りアクセス権限

    4. [Save] を選択します。

  7. [Overview] を選択し、[Download] を選択します。

オプトインリージョンの.rdb ファイルへの読み取りアクセス権を ElastiCache に付与する

AWS2019 年 3 月 20 日より前に導入されたリージョンはデフォルトで有効になっています。これらの作業を開始できますAWSただちにリージョン。2019 年 3 月 20 日以降に導入された アジアパシフィック (香港) や 中東 (バーレーン) などのリージョンはデフォルトでは無効になっています。これらのリージョンを使用するには、有効にする必要があります。詳細については、管理AWSのリージョン()AWS-GEN-REF;

許可するにはElastiCacheオプトイン () でバックアップファイルへの読み込みアクセスをに許可するにはAWSリージョン

  1. AWS Management Consoleにサインインし、Amazon S3 コンソール (https://console.aws.amazon.com/s3/) を開きます。

  2. .rdb ファイルを含む S3 バケットの名前を選択します。

  3. .rdb ファイルを含むフォルダの名前を選択します。

  4. .rdb バックアップファイルの名前を選択します。選択したファイルの名前は、ページ先頭のタブの上に表示されます。

    イメージ: S3 コンソールで選択されているファイル
  5. [Permissions] タブを選択します。

  6. [Permissions] で [Bucket policy] を選択します。

  7. ポリシーを更新して、オペレーションの実行に必要なアクセス許可を ElastiCache に付与します。

    • [ "Service" : "region-full-name.elasticache-snapshot.amazonaws.com" ]Principal に追加します。

    • スナップショットを Amazon S3 バケットにエクスポートするために必要な、以下のアクセス許可を追加します。

      • "s3:GetObject"

      • "s3:ListBucket"

      • "s3:GetBucketAcl"

    次に、更新されたポリシーの例を示します。

    { "Version": "2012-10-17", "Id": "Policy15397346", "Statement": [ { "Sid": "Stmt15399483", "Effect": "Allow", "Principal": { "Service": "ap-east-1.elasticache-snapshot.amazonaws.com" }, "Action": [ "s3:GetObject", "s3:ListBucket", "s3:GetBucketAcl" ], "Resource": [ "arn:aws:s3:::example-bucket", "arn:aws:s3:::example-bucket/backup1.rdb", "arn:aws:s3:::example-bucket/backup2.rdb" ] } ] }

ステップ 5: シードするElastiCacheクラスターと .rdb ファイルのデータをそれぞれ使用する

これで ElastiCache クラスターを作成し、.rdb ファイルのデータと提携する準備が整いました。クラスターを作成するには、「クラスターの作成」または「Redis レプリケーショングループをゼロから作成する」の手順に従います。Redis がクラスターエンジンとして選択されていることを確認してください。

さらに、お客様が ElastiCache に使用するよう指示した方法は、Amazon S3 にアップロードしたバックアップがどこにあるのかを検索するものですが、これはクラスターの作成に使用する方法によって異なります。

ElastiCache for Redis クラスターまたはレプリケーショングループと .rdb ファイルデータを提携させる

  • ElastiCache コンソールを使用する

    Redis エンジンを選択したら、[Advanced Redis settings] セクションを展開し、[Import data to cluster] を見つけます。[Seed RDB file S3 location] ボックスに、ファイルの Amazon S3 パスを入力します。複数の .rdb ファイルがある場合は、カンマ区切りのリストで各ファイルのパスを入力します。Amazon S3 パスは myBucket/myFolder/myBackupFilename.rdb のようになります。

  • の使用 AWS CLI

    create-cache-cluster または create-replication-group オペレーションを使用する場合、パラメーター --snapshot-arns を使用して、各 .rdb ファイルの完全修飾 ARN を指定します たとえば、arn:aws:s3:::myBucket/myFolder/myBackupFilename.rdb と指定します。ARN は、Amazon S3 に保存したバックアップファイルに解決される必要があります。

  • ElastiCache API の使用

    CreateCacheCluster または CreateReplicationGroup ElastiCache API オペレーションを使用する場合、パラメーター SnapshotArns を使用して、各 .rdb ファイルの完全修飾 ARN を指定します たとえば、arn:aws:s3:::myBucket/myFolder/myBackupFilename.rdb と指定します。ARN は、Amazon S3 に保存したバックアップファイルに解決される必要があります。

重要

Redis (クラスターモードが有効) クラスターを提携させる場合は、新しいクラスターまたはレプリケーショングループの各ノードグループ (シャード) を設定する必要があります。これを行うには、パラメータ --node-group-configuration (API: NodeGroupConfiguration) を使用します。詳細については、以下を参照してください。

クラスターの作成処理中、Redis バックアップ内のデータがクラスターに書き込まれます。ElastiCache イベントメッセージを表示して、進行状況をモニタリングできます。これを行うには、ElastiCache コンソールを参照し、[キャッシュイベント] を選択します。また、 を使用することもできますAWS ElastiCacheコマンドラインインターフェイスまたはElastiCacheAPI を使用してイベントメッセージを取得します。詳細については、「ElastiCache イベントの表示」を参照してください。