Helm 是 Kubernetes 的包管理工具,通过 Chart 模板简化 .NET 应用部署。创建 Chart 后,修改 values.yaml 配置镜像、服务等参数,调整 deployment.yaml 端口,可选启用 Ingress。使用 helm install 部署,helm upgrade 更新,helm rollback 回滚,支持多环境配置如 values.prod.yaml,并需注意 imagePullSecrets 与资源限制设置。

Helm 是 Kubernetes 的包管理工具,用来简化应用的部署和管理。它把一组 Kubernetes 资源打包成一个“Chart”,让你可以通过一条命令安装、升级或回滚整个应用。对于 .NET 应用来说,Helm 可以帮助你快速将服务、配置、镜像版本等统一管理并部署到集群中。
理解 Helm 的核心概念
Helm 的工作方式基于几个关键概念:
- Chart:一组 YAML 文件模板,定义了 Kubernetes 应用所需的资源(如 Deployment、Service、Ingress 等)
- Release:一次 Chart 的实际部署实例,每次安装都会生成一个新的 Release
- Repository:存放 Chart 的远程或本地仓库,类似 Docker Hub
- Values.yaml:用于自定义 Chart 行为的配置文件,比如镜像名称、副本数、环境变量等
准备你的 .NET 应用部署文件
假设你已经有一个 .NET Web API 或微服务项目,并已构建好 Docker 镜像并推送到镜像仓库(如 Docker Hub 或私有 Registry)。
确保你有以下内容:
- Dockerfile 正确打包了 .NET 应用
- 镜像已推送且可被 Kubernetes 拉取
- Kubernetes 集群可用(Minikube、AKS、EKS、Kind 等)
- kubectl 已配置并能访问集群
创建 Helm Chart 来部署 .NET 应用
在项目目录中执行命令创建 Chart:
helm create my-dotnet-app这会生成一个名为 my-dotnet-app 的目录。你需要修改其中的关键文件:
1. 修改 values.yaml
设置你的镜像信息和常用参数:
image:repository: your-dockerhub-username/your-dotnet-app
tag: "v1"
pullPolicy: IfNotPresent
service:
type: LoadBalancer
port: 80
2. 修改 templates/deployment.yaml
确保容器端口与 .NET 应用一致(默认是 80 和 443):
- name: http
containerPort: 80
protocol: TCP
如果你使用了 HTTPS,在 Program.cs 或 appsettings 中启用了 Kestrel 绑定,也要开放 443 端口。
3. (可选)添加 Ingress 规则
启用 ingress.enabled: true 并配置主机名或路径路由,便于外部访问。
部署 .NET 应用到 Kubernetes
在 Helm Chart 目录下运行:
helm install myapp ./my-dotnet-app查看部署状态:
kubectl get podskubectl get services
如果需要更新应用(比如换了镜像版本),修改 values.yaml 后运行:
helm upgrade myapp ./my-dotnet-app出错时可以快速回滚:
helm rollback myapp 1基本上就这些。Helm 让你不用手动维护一堆 YAML,特别适合 CI/CD 流程中的多环境部署(开发、测试、生产)。你可以为不同环境准备不同的 values 文件,比如 values.dev.yaml、values.prod.yaml,然后通过 -f 参数指定:
helm install myapp ./my-dotnet-app -f values.prod.yaml不复杂但容易忽略的是镜像拉取密钥(imagePullSecrets)和资源配置(CPU、内存),上线前记得补全。









