既存のアーキテクチャ
このセクションでは、単純な画像ホスティングの例を使用して、Kubernetesデプロイメントでストレージを扱う方法を探ります。サンプルストアアプリケーションの既存のデプロイメントから始めて、画像ホストとして機能するように変更します。UIコンポーネントはステートレスなマイクロサービスであり、水平スケーリングとPodの宣言的な状態管理が可能であるため、デプロイメントを示すための優れた例です。
UIコンポーネントの役割の1つは、静的な製品画像を提供することです。現在、これらの画像はビルドプロセス中にコンテナにバンドルされています。しかし、このアプローチには重要な制限があります - コンテナがデプロイされた後に新しい画像を追加することができません。この制限に対処するために、Amazon FSx for OpenZFSとKubernetesのPersistent Volumeを使用して共有ストレージ環境を作成するソリューションを実装します。これにより、複数のWebサーバーコンテナが需要に応じて動的にスケーリングしながら、アセットを提供することが可能になります。
現在のデプロイメントのボリューム構成を調べてみましょう:
~$kubectl describe deployment -n ui
Name: ui
Namespace: ui
[...]
Containers:
ui:
Image: public.ecr.aws/aws-containers/retail-store-sample-ui:1.2.1
Port: 8080/TCP
Host Port: 0/TCP
Limits:
memory: 1536Mi
Requests:
cpu: 250
memory: 1536Mi
[...]
Mounts:
/tmp from tmp-volume (rw)
Volumes:
tmp-volume:
Type: EmptyDir (a temporary directory that shares a pod's lifetime)
Medium: Memory
SizeLimit: <unset>
[...]
Volumesセクションを見ると、デプロイメントは現在、Podの存続期間中のみ存在するEmptyDirボリュームタイプを使用していることがわかります。これは、Podが終了すると、このボリュームに保存されているデータが完全に失われることを意味します。
しかし、UIコンポーネントの場合、製品画像は現在Spring Bootを介して静的Webコンテンツとして提供されているため、画像はファイルシステム上に存在していません。