40
12

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

カオスエンジニアリングツール「AWS Fault Injection Simulator(AWS FIS)」とは

Last updated at Posted at 2022-12-20

OpenStandiaアドベントカレンダー21日目は、カオスエンジニアリングツールであるAWS Fault Injection Simulatorの紹介です。

カオスエンジニアリングとは

あえて障害をおこし、その際にシステムが復旧できるかどうかを検証していくことです。

過去のOpenStandiaアドベントカレンダーでカオスエンジニアリングに関する記事があるので、興味ある方はぜひこちらもお読みください!

AWS Fault Injection Simulator(AWS FIS)とは

AWSが2021年から提供しているカオスエンジニアリングツールです。このツールを用いると、様々なAWSサービスに対して疑似的な障害を発生させることができます。

image.png
※ AWSサイトより引用

AWS FISの利用の流れは上図の通りです。AWS FISでは、障害を発生させることを「実験」と呼びます。

  1. Create an experiment template
    • どのような実験を行うかを「実験テンプレート」に記載します。
    • 実験テンプレートは複数作成可能です。
  2. Start the experiment
    • 実験テンプレートを選択し、実験を開始します。
    • このとき、Amazon CloudWatch等のモニタリングツールで監視を行います。
  3. Stop the experiment
    • 実験終了後も、システムの稼働状況を確認します。
  4. View results
    • 実験中・実験後のシステム稼働状況をもとに、システム構成の改善を検討していきます。

AWS FISを操作する方法について

AWS FISは他のAWSサービスと同様に、下記の通り様々な方法で操作できます。

IaCコンテンツも充実してきています。AWS FIS自体の機能が成熟してきたら、これらと組み合わせて利用する事例も出てきそうですね。

ちなみに、AWS FISをローカル上で試せるサードパーティー製フェイクツールも存在します。

実験テンプレートで設定できる内容について

実験テンプレートでは、TargetsとActionsとStop conditionsを指定できます。

image.png
※ AWS公式ドキュメントより引用

  • Targets(ターゲット):必須入力
    • どのAWSリソースで障害を起こすかを指定します。2022/12時点では、EC2やRDS、ECS、EKS、SSMが対象です。
    • AWSリソースを柔軟な方法で指定できます。例えば、EC2インスタンスを指定する際、下記のような選択をすることができます。
      • 特定のEC2インスタンスを手動で選択
      • 特定のタグがついたEC2インスタンスを選択
      • running状態のEC2インスタンス全て
  • Actions(アクション):必須入力
    • Targetsで指定したリソースにて、どのような障害を発生させるかを指定します。
    • 例えば下記アクションが存在します。他にも様々なアクションが存在し、それらはAWS FISの公式ガイドに記載されています。
      • EC2インスタンスを停止
      • RDSを再起動
      • EKSの特定のノードグループのインスタンスを終了
      • 指定したスコープのネットワークを遮断(2022/10に追加された機能)
  • Stop conditions(停止条件):オプション
    • 設定したAmazon CloudWatchアラームをトリガーとして、実験を安全に停止できます。停止条件を複数設定することも可能です。
    • 設定しない場合は、アクションで設定した継続時間が経過した後に実験を停止します。

個人的には、「スポットインスタンスを中断する」や「ある特定のVPCのネットワークを遮断する」といったユースケースを実験できる点が特に有用だと感じています。
今後、より多くのアクションに対応していくこと(特に、ネットワークまわり)を楽しみにしております。

実験を行う際のTips

実際に下記構成でAWS FISを動かしたときに気になった点をTipsとして記載します。

image.png

① AWS FISで実験を行うためには、AWS FIS自体に実験対象のAWSリソースを操作できる権限が必要です。
そのため、専用のIAMロールを作成し、実験テンプレートにアタッチする必要があります。

② 実験テンプレートは手動で削除できますが、実験結果は手動で削除できません。

③ オプション機能として、AWS FISの実験自体のログをAmazon S3かAmazon CloudWatch Logsに送信することができます。なお、取得できるログの例はこちらです。
ログがあるとどのような実験を行ったかをすぐ確認できるため、個人的にはログの取得を推奨します。

④ 実験中にAWSリソースをモニタリングするためには、Amazon CloudWatchが必須となります。

ダッシュボードでテスト中の挙動を確認する際、EC2インスタンスのデフォルト設定(基本モニタリング)では、メトリクスの取得間隔は5分です。

AWS FISのアクションの継続時間が5分未満の場合、デフォルトのままではメトリクス取得間隔が広すぎて正しいモニタリングができません。
以下のいずれかの対応を推奨します。

⑤ CPU使用率やネットワーク送信量をモニタリングする際、実験対象によっては「もともとのCPU利用率が低い」、「検証環境であるため、ユーザからのネットワークアクセスがない」等の理由でAmazon CloudWatchによる観測が難しいケースがあります。
その場合は、事前にCPU使用率やネットワーク送信量がある程度の値となるように仕込みを行うことで、実験結果を確認しやすくなります。

参考までに、私は下記スクリプトを作成しました。

  • sleepコマンドを繰り返し実行するスクリプト(実験対象のアプリケーションがデプロイされているインスタンス内に配置)
  • 実験対象のアプリケーションへ繰り返しcurlを投げるスクリプト(実験するAWS構成外に用意)

⑥ AWS FISを利用する際に発生するコストの計算にご注意ください。

AWS FIS自体は、実験を行うたびにアクションの実施時間だけコストがかかります。東京リージョンでは、1分あたり0.10ドル課金されます。
AWS FISのアクティビティログを取得している場合は、Amazon S3やAmazon CloudWatch Logsのコストが発生します。
(※AWS FISからのログ送信自体には課金は生じません。)

また、「Amazon CloudWatchの詳細モニタリング有効化」や「カスタムメトリクスの作成」を行うと、そこにもコストが発生します。

40
12
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
40
12

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?