はじめに
こんにちは、すぎもんです
いわゆる「コンテナ版HULFT」であるHULFT10 for Container Servicesを少しずつ触っております。今回はHULFT10 for Container Servicesでスケーリングをやってみます。
HULFT10 for Container Servicesのスケールはデータプレーンによって異なります。データプレーンがEC2の場合はEC2をスケールする方法とECSのタスクをスケールする方法がありますが、データプレーンがFargateの場合はECSのタスクをスケールする方法のみとなっています。
EC2とFargateのスケーリングの違いについて
ECS on Fargateは実行環境のスケーリング設定が不要です。データプレーンがEC2の場合はEC2のスケーリング設定が必要ですが、 Fargateの場合は実行環境のスケーリングを意識する必要がなく、ユーザはECSのスケーリング設定をするだけです。
過去記事
HULFT10 for Container Services で Amazon EFS内の実ファイルを確認してみる
HULFT10 for Container Servicesの監視アラームをSlackに通知してみた
HULFT10 for Container Servicesの運用監視のためにCloudWatchのダッシュボードを作成してみた
CloudFormationによるAWSリソース作成時のエラーに対処してみた
HULFT10 for Container Services でHULFT Squareのスクリプト実行してみた
Slack通知をHULFT10 for Container Servicesでしてみた
HULFT10 for Container ServicesでWebAPI による配信要求をしてみた
今回やること
今回はHULFT 10 for Container ServicesでのスケジュールによるEC2のスケール(EC2のみ) とスケジュールによるタスクのスケール(EC2・Fargate共通) を行います。
スケーリングの種類
・起動するEC2インスタンス数を維持するスケール(EC2のみ)
・スケジュールによるEC2のスケール(EC2のみ)※今回やること
・EC2の手動スケール(EC2のみ)
・EC2の自動スケール(EC2のみ)
・EC2の予測スケール(EC2のみ)
・タスクの自動スケール(EC2・Fargate共通)
・スケジュールによるタスクのスケール(EC2・Fargate共通)※今回やること
■スケジュール指定のEC2のスケール
→予定されたスケジュールに沿ってEC2の停止、起動。
■スケジュール指定のタスクのスケール
→予定されたスケジュールに沿ってタスクの追加、削除。
また、タスクの自動スケールはCPU使用率、NW負荷などの上限を超えた場合にタスクの追加、削除が実施されるようになります。
実施手順
<スケジュールによるEC2のスケール(EC2のみ)>
① Auto Scaling Groupの選択
② Auto Scaling Groupに対するアクションの作成
③ Auto Scaling Groupに対するアクションの詳細設定
④ Auto Scaling Groupのアクションの確認
⑤ スケールインの設定
<スケジュールによるタスクのスケール(EC2・Fargate共通)>
① 使用するコマンド
② cron式の使用
③ スケジュールを追加
④ スケジュールを確認
⑤ スケジュールを削除
スケジュールによるEC2のスケール(EC2のみ)
スケジュールにより、EC2をスケールするための設定を行います。
① Auto Scaling Groupの選択
AWS Management Consoleのナビゲーションペイン「Auto Scalingグループ」を選択し、対象のAuto Scalingグループを選択します。
② Auto Scaling Groupに対するアクションの作成
右部の[オートスケーリング]タブの最下層にある「予定されたアクション」の「予定されたアクションを作成する」を押下します。
③ Auto Scaling Groupに対するアクションの詳細設定
下記の通り、スケーリングしたいスケジュール(日時情報など)を入力し、作成を押下します。
④ Auto Scaling Groupのアクションの確認
「予定されたアクション」に③で作成したアクションが表示されます。
⑤ スケールインの設定
①~④でスケールアウトの設定をした場合、スケジュールに則り性能を向上させます。
そのままだと性能が向上したままになるため、システム負荷が低下するタイミングでスケールインするようにスケジュールする必要があります。
そのため、①~④の手順を参考に別途スケールインの設定を行う必要があります。
スケジュールによるタスクのスケール(EC2・Fargate共通)
スケジュール指定でタスクをスケールするための設定を行います。
① 使用するコマンド
よく使用するコマンドは以下になります。
コマンド名 | 説明 |
---|---|
put-scheduled-action | スケジュールを追加 |
describe-scheduled-actions | スケジュールを確認 |
delete-scheduled-action | スケジュールを削除 |
上記のコマンドを実行するためには、IAMで以下のアクションを許可する必要があります。
application-autoscaling:PutScheduledAction
application-autoscaling:DescribeScheduledActions
application-autoscaling:DeleteScheduledAction
② cron式の使用
定期的なスケジュールを作成する場合は以下のcron式を使用します。
③ スケジュールを追加
スケジュールを追加する場合は以下のコマンドを実行します。
例)毎週金曜日の18:00にスケールアウトまたはスケールインするスケジュールを追加する場合の設定例は以下になります。
④ スケジュールを確認
スケジュールを確認する場合は以下のコマンドを実行します。
⑤ スケジュールを削除
スケジュールを削除する場合は以下のコマンドを実行します。
最後に
いかがでしたでしょうか。
スケーリングは、HULFTがコンテナ対応したことで得られるメリットの一つだと思います。
皆さんもHULFT 10 for Container Servicesを導入した際は、スケーリングの設定を行い運用負荷の軽減を計画してみてはいかがでしょうか。
このブログでは、今後も様々なTopics記事や接続検証等、皆さんの参考になるような記事を投稿していきたいと思います!
ここまで読んでいただきありがとうございました。それでは、また!