Helm
Kubernetes のパッケージマネージャーで、アプリケーションのデプロイをテンプレート化して管理する
Helm とは
Helm は Kubernetes のパッケージマネージャーで、複数の Kubernetes マニフェスト (Deployment, Service, ConfigMap 等) を 1 つの Chart としてパッケージ化し、テンプレート変数で環境ごとの設定を切り替えてデプロイする。npm が Node.js のパッケージマネージャーであるように、Helm は Kubernetes のパッケージマネージャーだ。
Chart の構造
Helm Chart はディレクトリ構造で管理される。Chart.yaml にメタデータ、values.yaml にデフォルトのパラメータ値、templates/ 配下に Kubernetes マニフェストのテンプレートを配置する。デプロイ時に values.yaml の値がテンプレートに注入される。
my-app/
Chart.yaml # Chart のメタデータ
values.yaml # デフォルト値
templates/
deployment.yaml # テンプレート
service.yaml
ingress.yaml
テンプレート
テンプレートの例を示す。
# templates/deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ .Release.Name }}-app
spec:
replicas: {{ .Values.replicaCount }}
template:
spec:
containers:
- name: app
image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
resources:
requests:
cpu: {{ .Values.resources.requests.cpu }}
memory: {{ .Values.resources.requests.memory }}
# values.yaml (デフォルト)
replicaCount: 2
image:
repository: myapp
tag: latest
resources:
requests:
cpu: 100m
memory: 128Mi
環境ごとの values
環境ごとの values の例を示す。
# values-prod.yaml
replicaCount: 5
image:
tag: "1.2.3"
resources:
requests:
cpu: 500m
memory: 512Mi
# dev 環境
helm install my-app ./my-app
# prod 環境 (values-prod.yaml で上書き)
helm install my-app ./my-app -f values-prod.yaml
helm コマンド
helm コマンドの例を示す。
# インストール
helm install my-app ./my-app
# アップグレード
helm upgrade my-app ./my-app
# ロールバック
helm rollback my-app 1
# アンインストール
helm uninstall my-app
# リリース一覧
helm list
# テンプレートのレンダリング確認 (ドライラン)
helm template my-app ./my-app
公開 Chart の利用
公開 Chart の利用の例を示す。
# リポジトリの追加
helm repo add bitnami https://charts.bitnami.com/bitnami
# Chart の検索
helm search repo nginx
# インストール
helm install my-nginx bitnami/nginx
NGINX、PostgreSQL、Redis、Prometheus など、よく使うミドルウェアは公開 Chart で簡単にデプロイできる。
EKS での Helm
EKS では helm コマンドが kubectl と同じ kubeconfig を使用する。AWS Load Balancer Controller、ExternalDNS、cert-manager などの EKS アドオンも Helm Chart で管理する。
Helm vs Kustomize vs kubectl
Helm と Kustomize vs kubectl の違いを以下にまとめる。
| ツール | テンプレート | パッケージ管理 | 用途 |
|---|---|---|---|
| Helm | ✅ (Go テンプレート) | ✅ (Chart) | 複雑なアプリのデプロイ |
| Kustomize | ❌ (パッチベース) | ❌ | 環境ごとの差分管理 |
| kubectl apply | ❌ | ❌ | シンプルなデプロイ |
Helm の理解を深めるには関連書籍が参考になる。
この記事は役に立ちましたか?
関連用語
Kubernetes
コンテナのデプロイ、スケーリング、管理を自動化するオープンソースのオーケストレーションプラットフォーム
Deployment
Kubernetes で Pod のレプリカ数、更新戦略、ロールバックを宣言的に管理するリソース
Kubernetes Namespace
Kubernetes クラスター内のリソースを論理的に分離し、マルチテナントやチーム間の境界を設ける仕組み
CloudFormation
AWS のインフラをテンプレート (YAML/JSON) で宣言的に定義・管理する IaC サービス
Infrastructure as Code
インフラの構成をコードで定義し、バージョン管理・自動化・再現性を実現する手法
インフラテスト
IaC テンプレートやデプロイ済みインフラの正当性を自動テストで検証する手法
関連する記事
技術書を読む最適な場所はどこか - 喫茶店、図書館、自宅の科学
喫茶店の雑音が集中力を高める理由、図書館の静寂が深い思考を促す仕組みなど、読書環境が技術書の理解度に与える影響を科学的知見とともに解説します。
写経を超える - 技術書のコードを自分のプロジェクトに応用する方法
技術書のサンプルコードを写経するだけでは実力は伸びません。書籍のコードを自分のプロジェクトに応用し、実務で使える力に変える 5 つのステップを解説します。
本を読む前にパソコンの準備をしておこう
プログラミングの本を読み始めてから「環境構築ができない」と詰まる人が多いです。本を開く前にやっておくべき準備を、初心者向けにわかりやすく説明します。