feat: vdc_uid/nsxt_uid вынесены в tfvars; terraform.tfvars.template; README обновлён

This commit is contained in:
Naeel 2026-03-30 09:03:47 +03:00
parent 962002300f
commit 98105d75b4
4 changed files with 272 additions and 35 deletions

View File

@ -3,52 +3,86 @@
Создаёт: Создаёт:
- **vApp** — виртуальный каталог (контейнер для ВМ в VMware vDC) - **vApp** — виртуальный каталог (контейнер для ВМ в VMware vDC)
- **ВМ** — Ubuntu 22.04, 2 CPU / 2 GB RAM / 20 GB disk - **ВМ** — Ubuntu 22.04, 2 CPU / 2 GB RAM / 20 GB disk
- **Serverless-джобы** — устанавливают ПО на ВМ по SSH после создания
--- ---
## Что нужно сделать перед запуском ## Быстрый старт
### 1. Сгенерировать SSH-ключ
Публичный ключ прописывается в ВМ при создании — это единственный способ зайти по SSH.
Приватный ключ нужен хранить у себя.
```bash ```bash
ssh-keygen -t ed25519 -f ~/.ssh/sless-demo-vm -N "" -C "sless-demo-vm" cp terraform.tfvars.template terraform.tfvars
# Заполни terraform.tfvars (инструкция ниже)
terraform init
terraform apply
``` ```
Публичный ключ (`~/.ssh/sless-demo-vm.pub`) — строка вида: ---
```
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAA... sless-demo-vm ## Шаг 1 — Получить данные из Личного Кабинета
### API-токен
> Личный Кабинет → правый верхний угол → **«Профиль»** → **«API-токены»** → **«Создать токен»**
Скопируйте JWT-строку целиком (`eyJhbGciOiJS...`).
Один токен работает для обоих провайдеров — nubes (облако) и sless (serverless).
### UUID сервисов (vdc_uid и nsxt_uid)
> Личный Кабинет → **«Мои сервисы»** → нужный сервис → **«Параметры инстанса»** → поле UUID
| Параметр | Что искать в ЛК |
|---|---|
| `vdc_uid` | Сервис **«Виртуальный датацентр (vDC)»** → UUID |
| `nsxt_uid` | Сервис **«Сетевой шлюз периметра (Edge)»** → UUID |
UUID выглядит так: `e3c9e4f1-24da-4992-a003-f8a2a803a5f0`
> **Важно:** `vdc_uid` и `nsxt_uid` **не изменяются после первого `terraform apply`**.
> Менять их нельзя — сломается terraform state.
---
## Шаг 2 — Сгенерировать SSH-ключ для ВМ
Публичный ключ прописывается в ВМ при создании — это **единственный** способ зайти по SSH.
```bash
# Выполнить в папке examples/VM/
ssh-keygen -t ed25519 -f ./vm_key -N "" -C "sless-demo-vm"
``` ```
### 2. Заполнить terraform.tfvars Создаст два файла: `vm_key` (приватный) и `vm_key.pub` (публичный).
Открыть файл `terraform.tfvars` и заменить значения: ---
## Шаг 3 — Заполнить terraform.tfvars
```bash
cp terraform.tfvars.template terraform.tfvars
```
Открыть `terraform.tfvars` и заполнить:
```hcl ```hcl
# Ваш API-токен из панели Nubes api_token = "eyJhbGciOiJS..." # из ЛК (шаг 1)
api_token = "ВСТАВИТЬ_ТОКЕН" vm_public_key = "ssh-ed25519 AAAA..." # содержимое vm_key.pub (шаг 2)
vdc_uid = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" # из ЛК (шаг 1)
# Публичный ключ из шага 1 nsxt_uid = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" # из ЛК (шаг 1)
vm_public_key = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAA..."
``` ```
> **Токен** — берётся в панели Nubes: профиль → API-токены. Остальные параметры (`install_packages`, `base_packages` и т.д.) можно менять в любое время.
> **Ключ** — содержимое файла `~/.ssh/sless-demo-vm.pub` (публичный, не приватный!).
--- ---
## Запуск ## Запуск
```bash ```bash
cd examples/VM
terraform init terraform init
terraform apply terraform apply
``` ```
После `apply` в выводе будет: После успешного `apply` Terraform выведет:
``` ```
Outputs: Outputs:
@ -66,10 +100,58 @@ vapp_id = "..."
## Подключение по SSH ## Подключение по SSH
```bash ```bash
ssh -i ~/.ssh/sless-demo-vm ubuntu@<externalIp из outputs> ssh -i ./vm_key ubuntu@<externalIp из vm_state>
``` ```
Логин — `ubuntu` (задан в `vm.tf`). Логин всегда `ubuntu`.
---
## Управление установкой ПО
Установка выполняется через serverless-джобы — Terraform запускает k8s Job, который подключается к ВМ по SSH и устанавливает пакеты.
### Флаги установки (в terraform.tfvars)
| Переменная | Что делает | По умолчанию |
|---|---|---|
| `install_packages` | Устанавливает пакеты из `base_packages` | `true` |
| `install_nginx` | Устанавливает nginx | `true` |
| `install_docker` | Устанавливает Docker CE + docker-compose-plugin | `true` |
### Как изменить список пакетов
В `terraform.tfvars`:
```hcl
base_packages = ["jq", "htop", "curl", "git", "python3-pip"]
```
Любые стандартные apt-пакеты Ubuntu 22.04.
После изменения — увеличьте `install_run_id` и выполните `terraform apply`.
### Как перезапустить установку
sless_job — разовый джоб. При повторном `apply` Terraform не перезапускает его если ничего не изменилось.
Чтобы запустить все install-джобы заново — увеличьте `install_run_id` на 1:
```hcl
# было:
install_run_id = 3
# стало:
install_run_id = 4
```
Затем `terraform apply`. Установка идемпотентна — повторное выполнение не ломает систему.
### Как отключить отдельный компонент
```hcl
install_docker = false # не устанавливать Docker
```
После `apply` ресурс `sless_job.install_docker` будет удалён из state.
Docker на уже созданной ВМ останется — Terraform не удаляет пакеты.
--- ---
@ -79,15 +161,44 @@ ssh -i ~/.ssh/sless-demo-vm ubuntu@<externalIp из outputs>
terraform destroy terraform destroy
``` ```
Порядок автоматический: сначала suspend → потом delete. Без suspend удаление упадёт с ошибкой — это поведение Nubes, параметр `suspend_on_destroy = true` в ресурсах решает это. Порядок автоматический: сначала suspend → потом delete.
Параметр `suspend_on_destroy = true` решает это — без него удаление упадёт с ошибкой Nubes Услуга не остановлена»_.
--- ---
## Что можно менять ## Справочник параметров
| Параметр | Файл | Примечание | ### Можно менять в любое время
|----------|------|-----------|
| `vm_cpu`, `vm_ram`, `vm_disk` | `vm.tf` | Можно менять и переприменять | | Параметр | Файл | Эффект |
| `resource_name`, `vapp_name` | `vapp.tf` | **Не изменяется после создания** | |---|---|---|
| `image_vm`, `user_login`, `user_public_key` | `vm.tf` | **Не изменяется после создания** | | `vm_cpu`, `vm_ram`, `vm_disk` | `vm.tf` | ВМ будет изменена |
| `vdc_uid`, `nsxt_uid` | `vapp.tf` | **Не изменяется после создания** | | `install_packages/nginx/docker` | `terraform.tfvars` | Джоб добавится или удалится |
| `base_packages` | `terraform.tfvars` | Пакеты изменятся — увеличить `install_run_id` + apply |
| `install_run_id` | `terraform.tfvars` | Перезапускает все install-джобы |
### Нельзя менять после первого apply
| Параметр | Файл | Причина |
|---|---|---|
| `vdc_uid`, `nsxt_uid` | `terraform.tfvars` | Идентифицируют сервисы в terraform state |
| `resource_name`, `vapp_name` | `vapp.tf` | Уникальные имена ресурсов в Nubes |
| `image_vm`, `user_login` | `vm.tf` | Неизменяемые параметры ВМ |
| `vm_public_key` | `terraform.tfvars` | Прописывается в ВМ один раз при создании |
---
## Файлы проекта
| Файл | Назначение |
|---|---|
| `terraform.tfvars.template` | **Шаблон** — скопировать в `terraform.tfvars` и заполнить |
| `terraform.tfvars` | Ваши значения (не в git — содержит секреты) |
| `main.tf` | Провайдеры + переменные `api_token` и `vm_public_key` |
| `variables.tf` | Все остальные переменные с описаниями |
| `vapp.tf` | Ресурс vApp (контейнер ВМ) |
| `vm.tf` | Ресурс ВМ (Ubuntu 22.04) |
| `sless.tf` | Serverless-джобы для установки ПО |
| `outputs.tf` | Вывод IP-адреса и ID ресурсов |
| `vm_key` / `vm_key.pub` | SSH-ключ для доступа к ВМ |
| `functions/` | Код Python-функций для install-джобов |

View File

@ -0,0 +1,112 @@
# =============================================================================
# terraform.tfvars.template — шаблон конфигурации примера «ВМ в Nubes vDC»
# =============================================================================
#
# Скопируйте этот файл в terraform.tfvars и заполните все значения:
#
# cp terraform.tfvars.template terraform.tfvars
#
# terraform.tfvars НЕ коммитится в git (защищён .gitignore) —
# он содержит секретные данные (API-токен, SSH-ключ).
# =============================================================================
# =============================================================================
# 1. API-ТОКЕН
# =============================================================================
#
# Один токен для обоих провайдеров: nubes (облако) и sless (serverless).
#
# Где взять:
# Личный Кабинет Nubes → правый верхний угол → «Профиль» → «API-токены»
# → кнопка «Создать токен» → скопируйте JWT-строку целиком.
#
# Токен выглядит так: eyJhbGciOiJS...длинная строка...
# Вставьте в кавычки целиком, не разбивая на строки.
#
api_token = "ВСТАВИТЬ_API_ТОКЕН"
# =============================================================================
# 2. SSH-КЛЮЧ ДЛЯ ВМ
# =============================================================================
#
# Публичный ключ прописывается в ВМ при создании.
# Приватный ключ нужен для SSH-подключения к ВМ.
#
# Как сгенерировать:
# ssh-keygen -t ed25519 -f ./vm_key -N "" -C "sless-demo-vm"
# # Создаст два файла: vm_key (приватный) и vm_key.pub (публичный)
#
# vm_key.pub уже есть в папке — скопируйте его содержимое сюда.
# Строка выглядит так: ssh-ed25519 AAAA... имя-ключа
#
vm_public_key = "ВСТАВИТЬУБЛИЧНЫЙ_SSH_КЛЮЧ"
# =============================================================================
# 3. UUID СЕРВИСОВ NUBES (вdc_uid и nsxt_uid)
# =============================================================================
#
# Где взять:
# Личный Кабинет → «Мои сервисы» → найдите нужный сервис → раздел
# «Параметры инстанса» или «Технические параметры» → UUID.
#
# vdc_uid — это UUID услуги «Виртуальный датацентр (vDC)»
# Пример раздела ЛК: Мои сервисы → vDC → [ваш vDC] → UUID
#
# nsxt_uid — это UUID услуги «Сетевой шлюз периметра (Edge)»
# Пример раздела ЛК: Мои сервисы → Edge → [ваш Edge] → UUID
#
# Формат: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx (UUID v4)
#
# ВАЖНО: эти значения не изменяются после создания vApp.
# После первого terraform apply менять их нельзя — сломает state.
#
vdc_uid = "ВСТАВИТЬ_UUID_VDC"
nsxt_uid = "ВСТАВИТЬ_UUID_NSXT"
# =============================================================================
# 4. ФЛАГИ УСТАНОВКИ ПО НА ВМ
# =============================================================================
#
# Что устанавливать при terraform apply.
# Установка выполняется через serverless-джобы (sless_job) по SSH на ВМ.
# Каждый флаг — отдельный джоб, они выполняются независимо.
#
# true = установить
# false = не устанавливать (ресурс не создаётся вовсе)
#
install_packages = true # базовые apt-пакеты из списка base_packages ниже
install_nginx = true # nginx (веб-сервер)
install_docker = true # Docker CE + docker-compose-plugin
# =============================================================================
# 5. СПИСОК БАЗОВЫХ ПАКЕТОВ
# =============================================================================
#
# Эти пакеты устанавливаются когда install_packages = true.
# Любые стандартные apt-пакеты Ubuntu 22.04.
#
# Как изменить список:
# - Добавьте пакет: base_packages = ["jq", "htop", "curl", "git"]
# - Удалите пакет: уберите его из списка
# - После изменения: увеличьте install_run_id (см. ниже) и terraform apply
#
base_packages = ["jq", "python3-pip", "htop", "unzip"]
# =============================================================================
# 6. RUN_ID — триггер повторного запуска джобов
# =============================================================================
#
# sless_job — это разовые джобы (k8s Job). Terraform не перезапускает их
# автоматически если код не изменился. Чтобы запустить ВСЕ install-джобы
# заново (например, после изменения base_packages) — увеличьте это число на 1
# и выполните terraform apply.
#
# Например: было install_run_id = 3 → стало install_run_id = 4 → apply
#
install_run_id = 1

View File

@ -4,9 +4,9 @@
resource "nubes_vapp" "vapp" { resource "nubes_vapp" "vapp" {
resource_name = "vm-sless-vapp" resource_name = "vm-sless-vapp"
vapp_name = "vapp-sless" # Уникальное в рамках организации. Не изменяется после создания. vapp_name = "vapp-sless" # Уникальное в рамках организации. Не изменяется после создания.
vdc_uid = "e3c9e4f1-24da-4992-a003-f8a2a803a5f0" # UUID Услуги «Виртуальный датацентр (vDC)». Не изменяется после создания. vdc_uid = var.vdc_uid # UUID Услуги «Виртуальный датацентр (vDC)». В terraform.tfvars.
nsxt_uid = "0fe88e2a-31b6-4385-ad52-e27c6c0d38a6" # UUID Услуги «Сетевой шлюз периметра (Edge)». Не изменяется после создания. nsxt_uid = var.nsxt_uid # UUID Услуги «Сетевой шлюз периметра (Edge)». В terraform.tfvars.
adopt_existing_on_create = true adopt_existing_on_create = true
operation_timeout = "15m" operation_timeout = "15m"

View File

@ -35,3 +35,17 @@ variable "install_run_id" {
default = 1 default = 1
description = "Увеличь на 1 чтобы запустить все install-джобы заново" description = "Увеличь на 1 чтобы запустить все install-джобы заново"
} }
# ---- Идентификаторы сервисов Nubes ----------------------------------------
# Берутся из Личного Кабинета «Мои сервисы» нужный сервис параметры инстанса.
# Не изменяются после создания vApp.
variable "vdc_uid" {
type = string
description = "UUID услуги «Виртуальный датацентр (vDC)». Личный Кабинет → Мои сервисы → vDC → UUID."
}
variable "nsxt_uid" {
type = string
description = "UUID услуги «Сетевой шлюз периметра (Edge / NSX-T)». Личный Кабинет → Мои сервисы → Edge → UUID."
}