88 lines
5.4 KiB
Markdown
88 lines
5.4 KiB
Markdown
---
|
||
title: 01-base-helm
|
||
description:
|
||
published: true
|
||
date: 2023-11-09T15:06:26.646Z
|
||
tags: helm
|
||
editor: markdown
|
||
dateCreated: 2023-11-08T08:24:36.599Z
|
||
---
|
||
|
||
# Видео раз. Основы helm.
|
||
> Файлы для лабы:
|
||
[base-application.zip](/attachments/base-application.zip)
|
||
|
||
## Что такое helm?
|
||
|
||
Helm - это менеджер пакетов для kuberntes.
|
||
|
||
Как любой менеджер пакетов, Helm упрощает задачу управления жизненным циклом приложений.
|
||
|
||
Апдейт и удаление приложений достаточно простые (ну почти всегда). Поэтому в
|
||
данном цикле видео, мы не будем акцентировать внимание на этих действиях. В основном мы
|
||
займемся разбором создания собственных пакетов (chart), их установкой и кастомизацией.
|
||
|
||
### Документация
|
||
|
||
* [Helm](https://helm.sh/)
|
||
* [Go templates](https://pkg.go.dev/text/template)
|
||
|
||
### Как работает Helm
|
||
|
||
Пакет (helm chart или просто chart), обычно распространяется в виде стандартного архива в формате tar.gz
|
||
Внутри которого находятся:
|
||
* Описание чарта.
|
||
* Шаблоны манифестов.
|
||
* Конфигурационные параметры приложения по умолчанию.
|
||
* Другие, не обязательные файлы.
|
||
|
||
Для хранения набора таких пакетов можно использовать любой WEB сервер с обязательным файлом index.yaml, в котором
|
||
описываются чарты, которые предоставляются данным сервером. Но это конечно самый простой способ создания репозитория.
|
||
В принципе хранить архивы пакетов можно в специализированных системах или универсальных приложениях, которые
|
||
поддерживают helm charts типа Nexus, Harbor и т.п.
|
||
|
||
Так же чарт можно хранить например в локальной файловой системе, не запаковывая его в архив, в виде структуры файлов
|
||
и директорий. Но в этом случае затруднена версионность чарта. Т.е. для разных версий чарта необходимо создавать
|
||
отдельные директории. Ситуацию может облегчить хранения файлов чарта в системе контроля версии, например в git.
|
||
|
||
Основная задача helm:
|
||
* Получить от пользователя информацию, какие конфигурационные параметры приложения необходимо переопределить.
|
||
Обычно для этого используется кастомный файл values.
|
||
* Учитывая параметры, сгенерировать из шаблонов файлы манифестов приложений.
|
||
* Итоговые файлы манифестов поместить в kubernetes через kubernetes API.
|
||
|
||
Разумеется кроме работы с пакетами (шаблонами) helm умеет много чего полезного и по ходу изложения материала
|
||
мы познакомимся с этими функциями.
|
||
|
||
Helm версии 3 не требует наличия в кластере kubernetes дополнительного программного обеспечения.
|
||
|
||
Helm не может управлять приложениями, установленными помимо него.
|
||
|
||
## Установка
|
||
```bash
|
||
wget https://get.helm.sh/helm-v3.7.2-linux-amd64.tar.gz
|
||
tar -zxvf helm-v3.7.2-linux-amd64.tar.gz
|
||
mv linux-amd64/helm /usr/local/bin/helm
|
||
helm version
|
||
helm list
|
||
rm -r helm-v3.7.2-linux-amd64.tar.gz linux-amd64
|
||
```
|
||
|
||
## Задача
|
||
|
||
Изучать что-либо, просто так, без поставленной задачи бессмысленно. Поэтому сформулируем задачу, которую мы должны
|
||
будем решить.
|
||
|
||
У нас есть некоторое приложение - openresty, которое мы запускаем в кластере kubernetes. Для этого приложения мы написали
|
||
файлы [манифестов](../base-application).
|
||
|
||
Наша задача, сделать из этих манифестов чарт, так что бы мы могли при установке изменять парамеры деплоя,
|
||
конфигурационных файлов, сервисов и т.п.
|
||
|
||
У нас не стоит задачи сделать супер chart с возможностью кастомизации всего и вся. Только базовый функционал,
|
||
на котором можно понять как работает "кухня" helm charts.
|
||
|
||
## Видео
|
||
|
||
[<img src="https://img.youtube.com/vi/vv8SSYITzPE/maxresdefault.jpg" width="50%">](https://youtu.be/vv8SSYITzPE)
|