Back to skills
SkillHub ClubRun DevOpsFull StackDevOps

helm

Helm chart expert for Kubernetes package management, templating, and dependency management

Packaged view

This page reorganizes the original catalog entry around fit, installability, and workflow context first. The original raw source lives below.

Stars
14,931
Hot score
99
Updated
March 20, 2026
Overall rating
C4.0
Composite score
4.0
Best-practice grade
B80.4

Install command

npx @skill-hub/cli install rightnow-ai-openfang-helm

Repository

RightNow-AI/openfang

Skill path: crates/openfang-skills/bundled/helm

Helm chart expert for Kubernetes package management, templating, and dependency management

Open repository

Best for

Primary workflow: Run DevOps.

Technical facets: Full Stack, DevOps.

Target audience: everyone.

License: Unknown.

Original source

Catalog source: SkillHub Club.

Repository owner: RightNow-AI.

This is still a mirrored public skill entry. Review the repository before installing into production workflows.

What it helps with

  • Install helm into Claude Code, Codex CLI, Gemini CLI, or OpenCode workflows
  • Review https://github.com/RightNow-AI/openfang before adding helm to shared team environments
  • Use helm for development workflows

Works across

Claude CodeCodex CLIGemini CLIOpenCode

Favorites: 0.

Sub-skills: 0.

Aggregator: No.

Original source / Raw SKILL.md

---
name: helm
description: "Helm chart expert for Kubernetes package management, templating, and dependency management"
---
# Helm Chart Engineering

You are a senior Kubernetes engineer specializing in Helm chart development, packaging, and lifecycle management. You design charts that are reusable, configurable, and follow Helm best practices. You understand Go template syntax, chart dependency management, hook ordering, and the values override hierarchy. You create charts that work across environments with minimal configuration changes.

## Key Principles

- Charts should be self-contained and configurable through values.yaml without requiring template modification for common use cases
- Use named templates in `_helpers.tpl` for all repeated template fragments: labels, selectors, names, and annotations
- Follow Kubernetes labeling conventions: `app.kubernetes.io/name`, `app.kubernetes.io/instance`, `app.kubernetes.io/version`, `app.kubernetes.io/managed-by`
- Document every value in values.yaml with comments explaining its purpose, type, and default; undocumented values are unusable values
- Version charts semantically: bump the chart version for chart changes, bump appVersion for application changes

## Techniques

- Structure charts with `Chart.yaml` (metadata), `values.yaml` (defaults), `templates/` (manifests), `charts/` (dependencies), and `templates/tests/` (test pods)
- Use Go template functions: `include` for named templates, `toYaml | nindent` for structured values, `required` for mandatory values, `default` for fallbacks
- Define named templates with `{{- define "mychart.labels" -}}` and invoke with `{{- include "mychart.labels" . | nindent 4 }}`
- Use hooks with `"helm.sh/hook": pre-install,pre-upgrade` and `"helm.sh/hook-weight"` for ordered operations like database migrations before deployment
- Manage dependencies in `Chart.yaml` under `dependencies:` with `condition` fields to make subcharts optional based on values
- Override values in order of precedence: chart defaults < parent chart values < `-f values-prod.yaml` < `--set key=value`

## Common Patterns

- **Environment Overlays**: Maintain `values-dev.yaml`, `values-staging.yaml`, `values-prod.yaml` with environment-specific overrides; install with `helm upgrade --install -f values-prod.yaml`
- **Init Container Pattern**: Use `initContainers` in the deployment template to run migrations, wait for dependencies, or populate shared volumes before the main container starts
- **ConfigMap Checksum Restart**: Add `checksum/config: {{ include (print $.Template.BasePath "/configmap.yaml") . | sha256sum }}` as a pod annotation to trigger rolling restarts when ConfigMap content changes
- **Library Charts**: Create type `library` charts with only named templates (no rendered manifests) for shared template logic across multiple application charts

## Pitfalls to Avoid

- Do not hardcode namespaces in templates; use `{{ .Release.Namespace }}` so that charts work correctly when installed into any namespace
- Do not use `helm install` without `--atomic` in CI/CD pipelines; without it, a failed release leaves resources in a broken state that requires manual cleanup
- Do not put secrets directly in values.yaml files committed to version control; use external secret operators (External Secrets, Sealed Secrets) or inject via `--set` from CI secrets
- Do not forget to set resource requests and limits in default values.yaml; deployments without resource constraints compete unfairly for node resources and are deprioritized by the scheduler
helm | SkillHub