Назад к вопросам
Middle
78
questionbank
Как использовать шаблоны Helm?
Sobes Copilot
Получайте ответы в реальном времени
Ответ от нейросети
sobes.tech AI
Шаблоны Helm позволяют динамически генерировать манифесты Kubernetes на основе заданных значений и функций.
Основные компоненты шаблонизации:
- Шаблоны (Templates): YAML-файлы манифестов с внедренным синтаксисом Go template.
- Значения (Values): YAML-файлы или параметры командной строки, содержащие данные для заполнения шаблонов.
- Функции (Functions): Встроенные или кастомные функции Go template для логики обработки значений и генерации строк.
Пример базового шаблона deployment.yaml:
apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ .Release.Name }}-{{ .Chart.Name }}
spec:
replicas: {{ .Values.replicaCount }}
selector:
matchLabels:
app: {{ .Chart.Name }}
template:
metadata:
labels:
app: {{ .Chart.Name }}
spec:
containers:
- name: {{ .Chart.Name }}
image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
ports:
- containerPort: {{ .Values.service.port }}
Пример файла значений values.yaml:
replicaCount: 1
image:
repository: nginx
tag: latest
service:
port: 80
Использование помощников (helpers) для повторно используемых блоков кода, обычно в файле _helpers.tpl:
{{/*
Common labels
*/}}
{{- define "mychart.labels" -}}
helm.sh/chart: {{ include "mychart.chart" . }}
{{ include "mychart.selectorLabels" . }}
{{- if .Chart.AppVersion }}
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
{{- end }}
app.kubernetes.io/instance: {{ .Release.Name }}
app.kubernetes.io/managed-by: {{ .Release.Service }}
{{- end }}
{{/*
Selector labels
*/}}
{{- define "mychart.selectorLabels" -}}
app.kubernetes.io/name: {{ include "mychart.name" . }}
app.kubernetes.io/instance: {{ .Release.Name }}
{{- end }}
Вызов хелпера в шаблоне:
labels:
{{ include "mychart.labels" . | nindent 4 }}
Основные функции шаблонизатора Go template, часто используемые в Helm:
| Функция | Описание | Пример |
|---|---|---|
include |
Вставляет содержимое другого шаблона. | {{ include "my.helper" . }} |
nindent |
Отступы многострочного вывода. | `{{ .Values.multiline |
quote |
Оборачивает строку в кавычки. | `{{ .Values.someString |
default |
Устанавливает значение по умолчанию. | `{{ .Values.replicas |
required |
Отказывает в случае отсутствия значения. | {{ required "A database password is required!" .Values.database.password }} |
toJson |
Преобразует данные в JSON-строку. | `{{ .Values.config |
toYaml |
Преобразует данные в YAML-строку. | `{{ .Values.config |
Управление пробелами: - после {{ и перед }} обрезает пробельные символы.
{{- range .Values.items }}
- name: {{ .name }}
value: {{ .value | quote }}
{{- end -}}
Логика ветвления и циклы:
{{- if .Values.ingress.enabled }}
apiVersion: networking.k8s.io/v1
kind: Ingress
...
{{- end }}
{{- range $key, $value := .Values.configMapData }}
{{ $key }}: {{ $value | quote }}
{{- end }}
Тестирование шаблонов:
helm lint mychart # Базовая проверка синтаксиса
helm template mychart --values mychart/values.yaml # Рендеринг шаблона с значениями