🚀 ニフティ’s Notion

☁️ 【AWS2024 #6】クラウドコストの説明

コスト予測

AWSには、簡単にコスト予測をするためのツールが用意されています。

AWS Pricing Calculator

https://calculator.aws/#/

リソースごとの予測値を入れるだけで、簡単にコストを見積もることができます。
新しいサービスを作ったり、構成を変えたりする場合は事前に見積もりをしましょう。

https://calculator.aws/#/estimate?id=0d1acc8d6c9d2d9fa2854e382ae2599115d2e945

image block
使い方
  • ハンズオン2と似たようなチャットサービス
    • APIが二種類
      • チャットを書き込むためのAPI
      • チャットを読み込むためのAPI
    • ページ本体はcloudfront + s3
    • アクセス数
      • 1時間あたり1000アクセス
      • 1時間あたり100回書き込み
利用しているサービス
  • API Gateway
    • リクエスト回数: 1100req/h
      • 書き込み+読み込み
    • リクエストあたりの平均データ量: 2KB
  • Lambda
    • 書き込み
      • リクエスト回数: 100req/h
      • リクエストあたりの平均処理時間: 100ms
      • メモリ: 128MB
      • ストレージ: 512MB
    • 読み込み
      • リクエスト回数: 1000req/h
      • リクエストあたりの平均処理時間: 100ms
      • メモリ: 128MB
      • ストレージ: 512MB
  • cloudwatch logs(lambdaのみ)
    • データ取り込み量: 237.6MB/月
      • lambda1回あたり 0.3KB * 24h * 30d = 237.6MB
  • dynamodb
    • オンデマンドキャパシティ
    • テーブル: スタンダード
    • テーブルサイズ: 0GB
      • 1ヶ月のみ履歴保存 100rec*24h*30d*100B = 7.2MB/m
    • 平均アイテムサイズ: 100B
    • キャパシティユニット
      • write
        • 書き込み回数: 100/h
      • read
        • 読み込み回数: 1000/h
  • s3
    • スタンダード
    • ストレージ: 0.00002GB/m
  • cloudfront(東京リージョン)
    • インターネット転送量: 0.8GB
      • 1KB * 792000rec/m ≒ 0.8GB
    • リクエスト数: 2376000rec/m
      • 792000rec/m * 3ファイル(html・css・js) = 2376000rec/m
  • WAF
    • 制御リソース数: 1(cloudfront)
    • ルール数: 1
    • リクエスト数: 2.3 million/m
計算結果

コスト把握

事前に予測をしても、あくまで予測です。

しっかり現在どれだけのコストが掛かっているのか確かめましょう。
実は想定外のコストが発生しているかもしれません……

Cost Explorer

コスト確認には欠かせない、AWSの重要サービス

  • リソースごとのコストをグラフ・表形式で可視化
  • 毎時、日別、月別でグループ化
  • リソースのオペレーション単位でも可視化
  • フィルタ機能で条件を絞りながら確認可能
タグ付け

AWSリソースにはタグ🏷️ をつけることができる。

タグ付けをするメリット

  • リソースの情報を残す
    • 動作している環境
    • リソースの役割 etc.
  • Cost Explorerでの条件の絞り込みに使える(コスト配分タグのみ)
    • Application
    • ApplicationRole
    • Name
    • Project
    • Purpose
    • Service

クラウド破産・クラウド死☠️

クラウドでは、使い方次第ではとんでもない料金の請求を受ける可能性があります。

https://cloud-textbook.com/84/

主な要因

  • 設計・実装ミス
    • Lambdaの大量発火によるCloudWatch Logsの増大
    • ECS/Fargateの設定のせいでコンテナが起動しようとしては失敗するのを毎分繰り返す→ AWS Configで構成変更の記録がそのたびに走る
  • 第三者による不正利用
    • アクセスキー、シークレットアクセスキーを第三者に奪われ、上限までマイニング ⛏️ 用のEC2を建てられる

まとめ

  • AWSを使う際は、以下の二点に気を付ける
    • 事前にどの程度コストがかかるか予測する
    • 実際にどれだけコストが掛かっているか確認する