Claude-skill-registry helm-chart-patterns

Helm chart development patterns for packaging and deploying Kubernetes applications. Use when creating reusable Helm charts, managing multi-environment deployments, or building application catalogs for Kubernetes.

install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/helm-chart-patterns" ~/.claude/skills/majiayu000-claude-skill-registry-helm-chart-patterns && rm -rf "$T"
manifest: skills/data/helm-chart-patterns/SKILL.md
source content

Helm Chart Patterns

Expert guidance for developing production-grade Helm charts covering chart structure, templating patterns, multi-environment configuration, dependency management, testing strategies, and distribution workflows for Kubernetes application packaging.

When to Use This Skill

  • Creating reusable Helm charts for applications and services
  • Building application catalogs and chart repositories
  • Managing multi-environment deployments (dev, staging, production)
  • Implementing advanced templating with conditionals and loops
  • Managing chart dependencies and subcharts
  • Implementing chart hooks for lifecycle management
  • Testing and validating chart templates
  • Packaging and distributing charts via repositories
  • Using Helmfile for multi-chart orchestration

Core Concepts

Chart Types

  • Application charts: Standard deployable charts for your services
  • Library charts: Reusable template helpers (not directly installable)

Key Files

FilePurpose
Chart.yaml
Metadata, version, dependencies
values.yaml
Default configuration
values.schema.json
Input validation
templates/_helpers.tpl
Reusable template functions
templates/*.yaml
Kubernetes manifests

Template Essentials

  • Quote strings:
    {{ .Values.name | quote }}
  • Indent properly:
    {{- toYaml . | nindent 4 }}
  • Use helpers:
    {{ include "my-app.fullname" . }}
  • Check nil:
    {{- if .Values.optional }}

Quick Reference

TaskLoad reference
Chart structure & Chart.yaml
skills/helm-chart-patterns/references/chart-structure.md
Values file patterns
skills/helm-chart-patterns/references/values-patterns.md
Template patterns & functions
skills/helm-chart-patterns/references/template-patterns.md
Dependencies & subcharts
skills/helm-chart-patterns/references/dependencies.md
Hooks & lifecycle
skills/helm-chart-patterns/references/hooks.md
Testing patterns
skills/helm-chart-patterns/references/testing.md
Packaging & distribution
skills/helm-chart-patterns/references/packaging.md
Helmfile multi-chart
skills/helm-chart-patterns/references/helmfile.md
Best practices checklist
skills/helm-chart-patterns/references/best-practices.md

Workflow

  1. Structure - Set up chart directory with Chart.yaml and values.yaml
  2. Template - Create Kubernetes manifests with Go templating
  3. Helpers - Extract common patterns into _helpers.tpl
  4. Validate - Use values.schema.json for input validation
  5. Test - Lint, template, and run chart tests
  6. Package - Create .tgz and publish to repository

Essential Commands

# Development
helm create my-app          # Scaffold new chart
helm lint ./my-app          # Validate chart
helm template my-app ./my-app  # Render templates

# Dependencies
helm dependency update      # Download dependencies
helm dependency list        # Show dependencies

# Testing
helm install my-app ./my-app --dry-run --debug
helm test my-app

# Distribution
helm package ./my-app
helm repo index . --url https://charts.example.com
helm push my-app-1.0.0.tgz oci://registry.example.com/charts

Common Mistakes

  • Forgetting to quote strings in templates
  • Not using
    nindent
    for proper YAML formatting
  • Committing secrets to values files
  • Missing security contexts (runAsNonRoot, drop capabilities)
  • Not pinning dependency versions
  • Skipping values.schema.json validation
  • Not testing upgrades from previous versions

Resources