Назад к вопросам
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  # Рендеринг шаблона с значениями