feat: provider v0.1.10 — source_dir (zip внутри провайдера), убран archive провайдер из всех примеров
This commit is contained in:
parent
0fd2993ee7
commit
abd4612502
14
README.md
14
README.md
@ -34,7 +34,7 @@ terraform apply -auto-approve
|
||||
terraform output job_result
|
||||
|
||||
# Проверить функцию:
|
||||
curl -s $(terraform output -raw display_url)
|
||||
curl -s https://sless-api.kube5s.ru/fn/default/simple-py-time-display
|
||||
```
|
||||
|
||||
---
|
||||
@ -47,7 +47,7 @@ terraform init
|
||||
terraform apply -auto-approve
|
||||
|
||||
terraform output job_result
|
||||
curl -s $(terraform output -raw display_url)
|
||||
curl -s https://sless-api.kube5s.ru/fn/default/simple-node-time-display
|
||||
```
|
||||
|
||||
---
|
||||
@ -62,7 +62,7 @@ terraform init
|
||||
terraform apply -auto-approve
|
||||
|
||||
# Проверить HTTP-функцию:
|
||||
curl -s -X POST $(terraform output -raw trigger_url) \
|
||||
curl -s -X POST https://sless-api.kube5s.ru/fn/default/hello-http \
|
||||
-H 'Content-Type: application/json' -d '{"name":"World"}'
|
||||
|
||||
# Посмотреть результат джоба:
|
||||
@ -99,16 +99,16 @@ terraform output notes_url # CRUD
|
||||
terraform output notes_list_url # список всех записей
|
||||
|
||||
# Создать запись:
|
||||
curl -s -X POST "$(terraform output -raw notes_url)/add?title=Hello&body=World"
|
||||
curl -s -X POST "https://sless-api.kube5s.ru/fn/default/notes/add?title=Hello&body=World"
|
||||
|
||||
# Список записей:
|
||||
curl -s $(terraform output -raw notes_list_url)
|
||||
curl -s https://sless-api.kube5s.ru/fn/default/notes-list
|
||||
|
||||
# Обновить (id из предыдущего ответа):
|
||||
curl -s -X POST "$(terraform output -raw notes_url)/update?id=1&title=Updated&body=New+body"
|
||||
curl -s -X POST "https://sless-api.kube5s.ru/fn/default/notes/update?id=1&title=Updated&body=New+body"
|
||||
|
||||
# Удалить:
|
||||
curl -s -X POST "$(terraform output -raw notes_url)/delete?id=1"
|
||||
curl -s -X POST "https://sless-api.kube5s.ru/fn/default/notes/delete?id=1"
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
@ -1,17 +1,6 @@
|
||||
# 2026-03-08
|
||||
# 2026-03-08 / Изменено: 2026-03-09
|
||||
# http.tf — HTTP-функция: принимает запросы, возвращает приветствие.
|
||||
# Код: code/handler-http.js
|
||||
#
|
||||
# Использование:
|
||||
# terraform apply
|
||||
# curl -s -X POST $(terraform output -raw trigger_url) \
|
||||
# -H 'Content-Type: application/json' -d '{"name":"Naeel"}'
|
||||
|
||||
data "archive_file" "handler_http" {
|
||||
type = "zip"
|
||||
source_file = "${path.module}/code/handler-http.js"
|
||||
output_path = "${path.module}/dist/handler-http.zip"
|
||||
}
|
||||
|
||||
resource "sless_function" "hello_http" {
|
||||
name = "hello-http"
|
||||
@ -20,17 +9,13 @@ resource "sless_function" "hello_http" {
|
||||
memory_mb = 128
|
||||
timeout_sec = 30
|
||||
|
||||
code_path = data.archive_file.handler_http.output_path
|
||||
# filesha256 исходного файла — надёжнее чем output_md5 zip:
|
||||
# MD5 zip зависит от метаданных архива и может совпасть при разном содержимом
|
||||
code_hash = filesha256("${path.module}/code/handler-http.js")
|
||||
source_dir = "${path.module}/code"
|
||||
}
|
||||
|
||||
resource "sless_trigger" "hello_http" {
|
||||
name = "hello-http-trigger"
|
||||
type = "http"
|
||||
function = sless_function.hello_http.name
|
||||
# enabled = false — чтобы заморозить функцию (не удаляя ресурс), потом поставить зновь true
|
||||
enabled = true
|
||||
}
|
||||
|
||||
|
||||
@ -1,19 +1,6 @@
|
||||
# 2026-03-08
|
||||
# 2026-03-08 / Изменено: 2026-03-09
|
||||
# job.tf — одноразовая функция: суммирует числа из переданного массива.
|
||||
# Код: code/handler-job.js
|
||||
#
|
||||
# Использование:
|
||||
# terraform apply
|
||||
# # apply блокируется до завершения джоба (~2 мин kaniko + выполнение)
|
||||
# terraform output job_message
|
||||
#
|
||||
# Повторный запуск — изменить event_json и снова terraform apply.
|
||||
|
||||
data "archive_file" "handler_job" {
|
||||
type = "zip"
|
||||
source_file = "${path.module}/code/handler-job.js"
|
||||
output_path = "${path.module}/dist/handler-job.zip"
|
||||
}
|
||||
|
||||
resource "sless_function" "hello_job" {
|
||||
name = "hello-job"
|
||||
@ -22,13 +9,10 @@ resource "sless_function" "hello_job" {
|
||||
memory_mb = 128
|
||||
timeout_sec = 30
|
||||
|
||||
code_path = data.archive_file.handler_job.output_path
|
||||
# filesha256 исходного файла — надёжнее чем output_md5 zip
|
||||
code_hash = filesha256("${path.module}/code/handler-job.js")
|
||||
source_dir = "${path.module}/code"
|
||||
}
|
||||
|
||||
# Одноразовый запуск. Все поля immutable — изменение любого пересоздаёт джоб.
|
||||
# run_id: 0 = не запускать, 1+ = запустить. Для повторного запуска увеличь run_id (1→2→3...).
|
||||
# Одноразовый запуск. Для повторного запуска увеличь run_id (1→2→3...).
|
||||
resource "sless_job" "hello_run" {
|
||||
name = "hello-run"
|
||||
function = sless_function.hello_job.name
|
||||
|
||||
@ -8,11 +8,7 @@ terraform {
|
||||
required_providers {
|
||||
sless = {
|
||||
source = "terra.k8c.ru/naeel/sless"
|
||||
version = "~> 0.1.9"
|
||||
}
|
||||
archive = {
|
||||
source = "hashicorp/archive"
|
||||
version = "~> 2.0"
|
||||
version = "~> 0.1.10"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -14,12 +14,7 @@ terraform {
|
||||
# Провайдер для управления serverless функциями через sless API
|
||||
sless = {
|
||||
source = "terra.k8c.ru/naeel/sless"
|
||||
version = "~> 0.1.9"
|
||||
}
|
||||
# hashicorp/archive — для упаковки исходников в zip перед загрузкой
|
||||
archive = {
|
||||
source = "hashicorp/archive"
|
||||
version = "~> 2.0"
|
||||
version = "~> 0.1.10"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,22 +1,6 @@
|
||||
# 2026-03-09
|
||||
# notes-list.tf — функция для чтения всех заметок одним запросом.
|
||||
#
|
||||
# Отдельная от CRUD функция — «read-only» эндпоинт без роутинга.
|
||||
# Принимает GET или POST, параметры игнорирует.
|
||||
# Возвращает JSON-массив всех записей, сортировка: новые первые.
|
||||
#
|
||||
# Пример запроса:
|
||||
# curl https://sless-api.kube5s.ru/fn/default/notes-list
|
||||
# notes-list.tf — read-only эндпоинт: возвращает все заметки, сортировка новые первые.
|
||||
|
||||
# Упаковка исходников notes_list.py в zip.
|
||||
data "archive_file" "notes_list_zip" {
|
||||
type = "zip"
|
||||
source_dir = "${path.module}/code/notes-list"
|
||||
output_path = "${path.module}/dist/notes-list.zip"
|
||||
}
|
||||
|
||||
# Read-only функция в кластере.
|
||||
# entrypoint = "notes_list.list_notes" → файл notes_list.py, функция list_notes().
|
||||
resource "sless_function" "notes_list" {
|
||||
name = "notes-list"
|
||||
runtime = "python3.11"
|
||||
@ -28,12 +12,9 @@ resource "sless_function" "notes_list" {
|
||||
PG_DSN = var.pg_dsn
|
||||
}
|
||||
|
||||
code_path = data.archive_file.notes_list_zip.output_path
|
||||
code_hash = filesha256("${path.module}/code/notes-list/notes_list.py")
|
||||
source_dir = "${path.module}/code/notes-list"
|
||||
}
|
||||
|
||||
# HTTP-триггер для read-only функции.
|
||||
# Создаёт Ingress, URL доступен в outputs.tf.
|
||||
resource "sless_trigger" "notes_list_http" {
|
||||
name = "notes-list-http"
|
||||
type = "http"
|
||||
|
||||
@ -1,24 +1,11 @@
|
||||
# 2026-03-09
|
||||
# notes.tf — CRUD функция для управления заметками (CREATE / UPDATE / DELETE).
|
||||
#
|
||||
# Одна функция обрабатывает все операции — роутинг по sub-path URL.
|
||||
# Sub-path и query string пробрасывает прокси (invoke.go) → runtime добавляет
|
||||
# их в event как _path и _query.
|
||||
#
|
||||
# Маршруты (все методы принимаются, рекомендуется POST):
|
||||
# /fn/default/notes/add?title=...&body=... → INSERT, возвращает запись
|
||||
# /fn/default/notes/update?id=1&title=...&body=... → UPDATE, возвращает запись
|
||||
# /fn/default/notes/delete?id=1 → DELETE, возвращает {deleted: id}
|
||||
# Маршруты (рекомендуется POST):
|
||||
# /fn/default/notes/add?title=...&body=... → INSERT
|
||||
# /fn/default/notes/update?id=1&title=...&body=... → UPDATE
|
||||
# /fn/default/notes/delete?id=1 → DELETE
|
||||
|
||||
# Упаковка исходников notes_crud.py в zip.
|
||||
data "archive_file" "notes_crud_zip" {
|
||||
type = "zip"
|
||||
source_dir = "${path.module}/code/notes"
|
||||
output_path = "${path.module}/dist/notes.zip"
|
||||
}
|
||||
|
||||
# CRUD функция в кластере.
|
||||
# entrypoint = "notes_crud.crud" → файл notes_crud.py, функция crud().
|
||||
resource "sless_function" "notes_crud" {
|
||||
name = "notes"
|
||||
runtime = "python3.11"
|
||||
@ -30,13 +17,9 @@ resource "sless_function" "notes_crud" {
|
||||
PG_DSN = var.pg_dsn
|
||||
}
|
||||
|
||||
code_path = data.archive_file.notes_crud_zip.output_path
|
||||
code_hash = filesha256("${path.module}/code/notes/notes_crud.py")
|
||||
source_dir = "${path.module}/code/notes"
|
||||
}
|
||||
|
||||
# HTTP-триггер для CRUD функции.
|
||||
# Создаёт Ingress в кластере, URL доступен в outputs.tf.
|
||||
# Базовый URL: https://sless-api.kube5s.ru/fn/default/notes
|
||||
resource "sless_trigger" "notes_crud_http" {
|
||||
name = "notes-http"
|
||||
type = "http"
|
||||
|
||||
@ -5,17 +5,6 @@
|
||||
# Это сделано намеренно: функция выполняет произвольный SQL, и открывать её
|
||||
# наружу через HTTP было бы небезопасно.
|
||||
|
||||
# Упаковка исходников в zip для загрузки в кластер.
|
||||
# archive_file пересоздаёт zip при изменении любого файла в source_dir.
|
||||
data "archive_file" "sql_runner_zip" {
|
||||
type = "zip"
|
||||
source_dir = "${path.module}/code/sql-runner"
|
||||
output_path = "${path.module}/dist/sql-runner.zip"
|
||||
}
|
||||
|
||||
# Сама функция в кластере.
|
||||
# entrypoint = "sql_runner.run_sql" → файл sql_runner.py, функция run_sql().
|
||||
# memory_mb=128 достаточно — DDL запросы не требуют памяти на вычисления.
|
||||
resource "sless_function" "sql_runner" {
|
||||
name = "sql-runner"
|
||||
runtime = "python3.11"
|
||||
@ -27,7 +16,5 @@ resource "sless_function" "sql_runner" {
|
||||
PG_DSN = var.pg_dsn
|
||||
}
|
||||
|
||||
code_path = data.archive_file.sql_runner_zip.output_path
|
||||
# code_hash — при изменении кода terraform пересобирает образ функции
|
||||
code_hash = filesha256("${path.module}/code/sql-runner/sql_runner.py")
|
||||
source_dir = "${path.module}/code/sql-runner"
|
||||
}
|
||||
|
||||
@ -19,11 +19,7 @@ terraform {
|
||||
required_providers {
|
||||
sless = {
|
||||
source = "terra.k8c.ru/naeel/sless"
|
||||
version = "~> 0.1.9"
|
||||
}
|
||||
archive = {
|
||||
source = "hashicorp/archive"
|
||||
version = "~> 2.0"
|
||||
version = "~> 0.1.10"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,14 +1,7 @@
|
||||
# Создано: 2026-03-09
|
||||
# Создано: 2026-03-09 / Изменено: 2026-03-09
|
||||
# time-display.tf — HTTP-функция, доступная по URL после apply.
|
||||
# Получает результат джоба (из time-getter.tf) через переменную окружения JOB_TIME.
|
||||
|
||||
# Упаковываем код функции в zip для загрузки
|
||||
data "archive_file" "time_display_zip" {
|
||||
type = "zip"
|
||||
source_dir = "${path.module}/code/time_display"
|
||||
output_path = "${path.module}/dist/time_display.zip"
|
||||
}
|
||||
|
||||
# HTTP-функция — отвечает на запросы по URL из outputs.tf
|
||||
resource "sless_function" "time_display" {
|
||||
name = "simple-node-time-display" # уникальное имя в namespace
|
||||
@ -22,8 +15,7 @@ resource "sless_function" "time_display" {
|
||||
JOB_TIME = sless_job.run_getter.message
|
||||
}
|
||||
|
||||
code_path = data.archive_file.time_display_zip.output_path
|
||||
code_hash = filesha256("${path.module}/code/time_display/time_display.js") # для пересборки при изменении кода
|
||||
source_dir = "${path.module}/code/time_display"
|
||||
|
||||
depends_on = [sless_job.run_getter] # ждём завершения джоба перед деплоем функции
|
||||
}
|
||||
|
||||
@ -1,15 +1,8 @@
|
||||
# Создано: 2026-03-09
|
||||
# Создано: 2026-03-09 / Изменено: 2026-03-09
|
||||
# time-getter.tf — скрипт который запускается ОДИН РАЗ при terraform apply.
|
||||
# После запуска его результат доступен через: sless_job.run_getter.message
|
||||
# Смотри time-display.tf — там этот результат передаётся в функцию.
|
||||
|
||||
# Упаковываем код скрипта в zip для загрузки
|
||||
data "archive_file" "time_getter_zip" {
|
||||
type = "zip"
|
||||
source_dir = "${path.module}/code/time_getter"
|
||||
output_path = "${path.module}/dist/time_getter.zip"
|
||||
}
|
||||
|
||||
# Функция для скрипта — без HTTP-триггера, вызывается только через джоб ниже
|
||||
resource "sless_function" "time_getter" {
|
||||
name = "simple-node-time-getter" # уникальное имя в namespace
|
||||
@ -17,8 +10,7 @@ resource "sless_function" "time_getter" {
|
||||
entrypoint = "time_getter.getTime" # файл.функция в code/time_getter/
|
||||
memory_mb = 64
|
||||
|
||||
code_path = data.archive_file.time_getter_zip.output_path
|
||||
code_hash = filesha256("${path.module}/code/time_getter/time_getter.js") # для пересборки при изменении кода
|
||||
source_dir = "${path.module}/code/time_getter"
|
||||
}
|
||||
|
||||
# Джоб — запускает функцию time_getter один раз прямо при apply.
|
||||
|
||||
@ -18,11 +18,7 @@ terraform {
|
||||
required_providers {
|
||||
sless = {
|
||||
source = "terra.k8c.ru/naeel/sless"
|
||||
version = "~> 0.1.9"
|
||||
}
|
||||
archive = {
|
||||
source = "hashicorp/archive"
|
||||
version = "~> 2.0"
|
||||
version = "~> 0.1.10"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,14 +1,7 @@
|
||||
# Создано: 2026-03-09
|
||||
# Создано: 2026-03-09 / Изменено: 2026-03-09
|
||||
# time-display.tf — HTTP-функция, доступная по URL после apply.
|
||||
# Получает результат джоба (из time-getter.tf) через переменную окружения JOB_TIME.
|
||||
|
||||
# Упаковываем код функции в zip для загрузки
|
||||
data "archive_file" "time_display_zip" {
|
||||
type = "zip"
|
||||
source_dir = "${path.module}/code/time_display"
|
||||
output_path = "${path.module}/dist/time_display.zip"
|
||||
}
|
||||
|
||||
# HTTP-функция — отвечает на запросы по URL из outputs.tf
|
||||
resource "sless_function" "time_display" {
|
||||
name = "simple-py-time-display" # уникальное имя в namespace
|
||||
@ -22,8 +15,7 @@ resource "sless_function" "time_display" {
|
||||
JOB_TIME = sless_job.run_getter.message
|
||||
}
|
||||
|
||||
code_path = data.archive_file.time_display_zip.output_path
|
||||
code_hash = filesha256("${path.module}/code/time_display/time_display.py") # для пересборки при изменении кода
|
||||
source_dir = "${path.module}/code/time_display"
|
||||
|
||||
depends_on = [sless_job.run_getter] # ждём завершения джоба перед деплоем функции
|
||||
}
|
||||
|
||||
@ -1,15 +1,8 @@
|
||||
# Создано: 2026-03-09
|
||||
# Создано: 2026-03-09 / Изменено: 2026-03-09
|
||||
# time-getter.tf — скрипт который запускается ОДИН РАЗ при terraform apply.
|
||||
# После запуска его результат доступен через: sless_job.run_getter.message
|
||||
# Смотри time-display.tf — там этот результат передаётся в функцию.
|
||||
|
||||
# Упаковываем код скрипта в zip для загрузки
|
||||
data "archive_file" "time_getter_zip" {
|
||||
type = "zip"
|
||||
source_dir = "${path.module}/code/time_getter"
|
||||
output_path = "${path.module}/dist/time_getter.zip"
|
||||
}
|
||||
|
||||
# Функция для скрипта — без HTTP-триггера, вызывается только через джоб ниже
|
||||
resource "sless_function" "time_getter" {
|
||||
name = "simple-py-time-getter" # уникальное имя в namespace
|
||||
@ -17,8 +10,7 @@ resource "sless_function" "time_getter" {
|
||||
entrypoint = "time_getter.get_time" # файл.функция в code/time_getter/
|
||||
memory_mb = 64
|
||||
|
||||
code_path = data.archive_file.time_getter_zip.output_path
|
||||
code_hash = filesha256("${path.module}/code/time_getter/time_getter.py") # для пересборки при изменении кода
|
||||
source_dir = "${path.module}/code/time_getter"
|
||||
}
|
||||
|
||||
# Джоб — запускает функцию time_getter один раз прямо при apply.
|
||||
|
||||
Loading…
Reference in New Issue
Block a user