10
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

ZOZOAdvent Calendar 2024

Day 9

Flaggerを利用しているKubernetes環境にKEDAを導入する方法

Last updated at Posted at 2024-12-08

本記事

前回、Kubernetes Podのゼロスケールを実現するためにKEDAの活用を紹介しました。
今回はFlaggerを利用している場合のKEDAの導入方法と注意ポイントについて紹介します。

Flagger

Kubernetes上で実行されるアプリケーションのリリースプロセスを自動化するプログレッシブデリバリーツールです。

公式でKEDAに関するドキュメントも用意されています。

Canary

Horizontal Pod Autoscaler(HPA)でPodの自動スケーリングを行なっている場合、カスタムリソースであるCanaryリソースの.spec.autoscalerRefは以下のようになっています。

autoscalerRef:
  apiVersion: autoscaling/v2
  kind: HorizontalPodAutoscaler
  name: sample-hpa

KEDAを導入する場合は.spec.autoscalerRefにKEDAのカスタムメトリクスであるScaledObjectを指定します。

autoscalerRef:
  apiVersion: keda.sh/v1alpha1
  kind: ScaledObject
  name: sample-scaledobject

上記を設定することでPodの自動スケーリングはHPAからScaledObject(が内部で作成するHPA)に切り替わります。

ScaledObjectのデプロイ

Flaggerを利用している場合にScaledObjectのデプロイにおいて注意したいポイントがあります。

ScaledObjectは内部でHPAを作成するため、既存で利用しているHPAが存在しているとHPAの重複エラーが発生します。

Error from server (the workload 'sample-deployment' of type 'apps/v1.Deployment' is already managed by the hpa 'sample-hpa'): admission webhook "vscaledobject.kb.io" denied the request: the workload 'sample-deployment' of type 'apps/v1.Deployment' is already managed by the hpa 'sample-hpa'

エラーの回避策がドキュメントにあり、既存のHPAの所有権をScaledObjectに譲渡します。そうすることでエラーは発生せず、既存のHPAの設定がScaledObjectによって上書きされます。

ただしここが注意したいポイントであり、Flaggerを利用しているとこの設定を追加しても正常にScaledObjectをデプロイすることはできません。

metadata:
  annotations:
    scaledobject.keda.sh/transfer-hpa-ownership: "true"
spec:
   advanced:
      horizontalPodAutoscalerConfig:
        name: {name-of-hpa-resource}

なぜデプロイが失敗するのか?

Canaryリソースで以下のように定義すると、sample-hpasample-hpa-primaryというようにCanary Pod用とPrimary Pod用の2つのHPAが作られます。

autoscalerRef:
  apiVersion: autoscaling/v2
  kind: HorizontalPodAutoscaler
  name: sample-hpa

先述したエラー回避策を設定するとsample-hpaには適用されますがsample-hpa-primaryには適用されません。

metadata:
  annotations:
    scaledobject.keda.sh/transfer-hpa-ownership: "true"
spec:
   advanced:
      horizontalPodAutoscalerConfig:
        name: sample-hpa

そのためScaledObjectをデプロイしてカナリアリリースが始まってもsample-hpa-primaryの重複エラーが発生してしまいます。

Warning Synced flagger creating Keda ScaledObject sample-scaledobject-primary.sample-ns failed: admission webhook "vscaledobject.kb.io" denied the request: the workload 'sample-deployment-primary' of type 'apps/v1.Deployment 
│ ' is already managed by the hpa 'sample-hpa-primary'

この事象はissueが切られています。

どうすれば良いのか?

選択肢は3つあると思います。

  1. 既存のHPAを削除してからScaledObjectをデプロイする
  2. Admission Webhooksのバリデーションを無効化
  3. 事象が改善されるのを待つ

「2.Admission Webhooksのバリデーションを無効化」は設定方法がドキュメントにありますが、KEDAを利用する上でのベストプラクティスとしてScaledObject(が内部で作成するHPA)とHPAは競合するリスクがあるため併用しないようにとあります。選択肢から外すのが無難です。

筆者は「1. 既存のHPAを削除してからScaledObjectをデプロイする」を選択しました。
既存のHPAを削除してからScaledObjectのデプロイが完了するまでは自動スケールされないため、アプリケーションの負荷が低い時間帯に実施したり、あらかじめ十分なPod数に拡張したりするなど対策することをおすすめします。

最後の「3. 事象が改善されるのを待つ」については、筆者がKEDAを導入した際にはissueが切られているだけでいつ改善されるか分からない状況でしたが、現在はissueに対するPull Requestが作成されています。これからKEDAの導入を検討されるのであれば改善されるのを待つこともありかもしれません。

終わりに

Flaggerを利用しているKubernetes環境にKEDAを導入する方法と注意ポイントを紹介しました。これからKEDAを導入しようと考えている人の参考になれば幸いです。

10
0
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
10
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?