AWS Secrets Managerのシングルユーザーローテーションを設定する - AWS Secrets Manager

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

AWS Secrets Managerのシングルユーザーローテーションを設定する

このチュートリアルでは、データベース認証情報を含むシークレットの単一ユーザーローテーションを設定する方法を学習します。シングルユーザーローテーションは、Secrets Manager がシークレットとデータベースの両方でユーザーの認証情報を更新するローテーション戦略です。詳細については、「ローテーション戦略: シングルユーザー」を参照してください。

チュートリアルを終了したら、チュートリアルからリソースをクリーンアップすることをお勧めします。本番環境では使用しないでください。

Secrets Manager のローテーションでは、 AWS Lambda 関数を使用してシークレットとデータベースを更新します。Lambda 関数を使用する場合のコストについては、「料金」を参照してください。

アクセス許可

このチュートリアルの前提条件として、 AWS アカウントの管理者権限が必要となります。本番稼働環境では、各ステップで異なるロールを使用するのがベストプラクティスとなります。例えば、Amazon RDS データベースの作成にはデータベース管理者権限を持つロールを使用し、VPC とセキュリティグループの設定にはネットワーク管理者権限を持つロールを使用します。チュートリアルの各ステップでは同じアイデンティティを使用することが推奨されます。

本番稼働環境で許可を設定する方法については、「の認証とアクセスコントロール AWS Secrets Manager」を参照してください。

前提条件

このチュートリアルの前提条件は の交代ユーザーローテーションを設定する AWS Secrets Manager です。最初のチュートリアルが完了した時点で、リソースのクリーンアップを実行しないでください。このチュートリアルの後、Amazon RDS データベースと、データベースの管理者認証情報を含む Secrets Manager シークレットを備えた現実的な環境ができました。データベースユーザーの認証情報を含む 2 番目のシークレットもありますが、このチュートリアルではそのシークレットを使用しません。

また、管理者認証情報を使用してデータベースに接続するための接続が、MySQL Workbench に設定されます。

ステップ 1: Amazon RDS データベースユーザーを作成する

まず、シークレットにその認証情報を保存するユーザーが必要になります。ユーザーを作成するには、シークレットに保存されている管理者認証情報を使用して Amazon RDS データベースにログインします。簡単にするために、このチュートリアルでは、データベースへの完全なアクセス許可を持つユーザーを作成します。運用環境では、これは一般的ではないため、最小権限の原則に従うことをお勧めします。

管理者パスワードを取得するには
  1. Amazon RDS コンソールで、データベースに移動します。

  2. [Configuration] (設定) タブの [Master Credentials ARN] (マスター認証情報 ARN)で、[Manage in Secrets Manager] (Secrets Managerの管理) を選択します。

    Secrets Manager コンソールが開きます。

  3. シークレットの詳細ページで、[Retrieve secret value] (シークレット値の取得) を選択します。

  4. パスワードは [Secret value] (シークレット値) セクションに表示されます。

データベースユーザーを作成するには
  1. MySQL Workbench で、接続を右クリックしSecretsManagerTutorial接続の編集 を選択します。

  2. [Manage Server Connections] (サーバー接続を管理) ダイアログボックスで、[Username] (ユーザーネーム) に admin と入力し、[Close] (閉じる) を選択します。

  3. MySQL Workbench に戻り、接続 を選択しますSecretsManagerTutorial

  4. シークレットから取得した管理者パスワードを入力します。

  5. MySQL Workbenchの[Query] (クエリ) ウィンドウで、次のコマンド (強力なパスワードを含む) を入力し、[Execute] (実行) を選択します。

    CREATE USER 'dbuser'@'%' IDENTIFIED BY 'EXAMPLE-PASSWORD'; GRANT ALL PRIVILEGES ON myDB . * TO 'dbuser'@'%';

    [Output] (出力) ウィンドウに、コマンドが実行されたことが表示されます。

ステップ 2: データベースユーザー認証情報のシークレットを作成する

次に、作成したばかりのユーザーの認証情報を格納するためのシークレットを作成し、即時ローテーションを含む自動ローテーションをオンにします。Secrets Manager はシークレットをローテーションします。これは、パスワードがプログラムによって生成されることを意味します - 誰もこの新しいパスワードを見たことはありません。ローテーションをすぐに開始すると、ローテーションが正しく設定されているかどうかを判断するのにも役立ちます。

  1. Secrets Manager のコンソール (https://console.aws.amazon.com/secretsmanager/) を開きます。

  2. [Store a new secret] (新しいシークレットを保存する) を選択します。

  3. [Choose secret type] (シークレットタイプを選択する) ページで、次の操作を行います。

    1. [Secret type] (シークレットタイプ) で、[Credentials for Amazon RDS database] (Amazon RDS データベースの認証情報) を選択します。

    2. [Credentials] (認証情報) で、ユーザーネーム dbuser と、MySQL Workbench を使って作成したデータベースユーザー向けに入力したパスワードを入力します。

    3. [Database] (データベース) で、secretsmanagertutorialdb を選択します。

    4. [次へ] をクリックします。

  4. [Configure secret] (シークレットを設定する) ページで、[Secret name] (シークレット名) に SecretsManagerTutorialDbuser と入力し、[Next] (次) を選択します。

  5. [Configure Routing] (ローテーションを設定する) ページで、以下を実行します。

    1. [Automatic rotation] (自動ローテーション) を有効化します。

    2. [Rotation schedule] (ローテーションスケジュール) で、[Days] (日数) のスケジュールを設定します: [Duration] (期間) の 2 日間: 2h[Rotate immediately] (すぐにローテーションする) は選択したままにしておきます。

    3. [Rotation function] (ローテーション関数) で [Create a rotation function] (ローテーション関数を作成) を選択し、[Function Name] (関数名) に tutorial-single-user-rotation と入力します。

    4. [ローテーション戦略] で、[単一ユーザー] を選択します。

    5. [次へ] をクリックします。

  6. [Review] (確認) ページで [Store] (保存) を選択します。

    Secrets Manager はシークレットの詳細ページに戻ります。ローテーション設定のステータスは、ページの上部で確認できます。Secrets Manager は CloudFormation を使用して、Lambda ローテーション関数や Lambda 関数を実行する実行ロールなどのリソースを作成します。 CloudFormation が終了すると、バナーはローテーションが予定されているシークレット に変わります。これで、最初のローテーションは完了です。

ステップ 3: ローテーションされたパスワードをテストする

最初のシークレットローテーションが完了すると (所要時間は数秒)、シークレットに有効な認証情報が残っているかどうかを確認できます。シークレット内のパスワードが、元の認証情報から変更されました。

シークレットから新しいパスワードを取得するには
  1. Secrets Manager のコンソール (https://console.aws.amazon.com/secretsmanager/) を開きます。

  2. [Secrets] (シークレット) を選択し、シークレット SecretsManagerTutorialDbuser を選択します。

  3. [Secret details] (シークレットの詳細) ページで、下へスクロールし、[Retrieve secret value] (シークレットの値を取得する) を選択します。

  4. [Key/value] (キー/バリュー) テーブルで、passwordシークレットの値をコピーします。

認証情報をテストするには
  1. MySQL Workbench で、接続を右クリックしSecretsManagerTutorial接続の編集 を選択します。

  2. [Manage Server Connections] (サーバー接続を管理) ダイアログボックスで、[Username] (ユーザーネーム) に dbuser と入力し、[Close] (閉じる) を選択します。

  3. MySQL Workbench に戻り、接続 を選択しますSecretsManagerTutorial

  4. [Open SSH Connection] (SSH 接続を開く) ダイアログボックスで、シークレットから取得したパスワードを [Password] (パスワード) に貼り付けて、[OK] をクリックします。

    認証情報が有効であれば、MySQL Workbench でデータベースの設計ページが開きます。

ステップ 4: リソースをクリーンアップする

料金を発生させないために、このチュートリアルで作成したシークレットは削除します。手順については、「AWS Secrets Manager シークレットを削除する」を参照してください。

前のチュートリアルで作成したリソースをクリーンアップするには、ステップ 4: リソースをクリーンアップする を参照してください。

次のステップ