WASM-Funktionen
WASM-Funktionen sind Registry-Eintraege, die WebAssembly-Code ausfuehren. Zwei Entry Kinds stehen zur Verfuegung: function.wat fuer Inline-WAT-Quellcode und function.wasm fuer vorkompilierte Binaries.
Inline-WAT-Funktionen
Definieren Sie kleine WASM-Funktionen direkt in Ihrer _index.yaml im WebAssembly-Text-Format:
entries:
- name: answer
kind: function.wat
source: |
(module
(func (export "answer") (result i32)
i32.const 42
)
)
wit: |
answer: func() -> s32;
method: answer
pool:
type: inline
Fuer groessere WAT-Quellen verwenden Sie eine Dateireferenz:
- name: answer
kind: function.wat
source: file://answer.wat
wit: |
answer: func() -> s32;
method: answer
pool:
type: inline
WAT-Konfigurationsfelder
| Field | Required | Beschreibung |
|---|---|---|
source |
Yes | Inline-WAT-Quellcode oder file://-Referenz |
method |
Yes | Name der exportierten Funktion, die aufgerufen wird |
wit |
No | WIT-Signatur fuer Raw/Core-Module |
pool |
No | Worker-Pool-Konfiguration |
transport |
No | Input/Output-Mapping (Standard: payload) |
imports |
No | Host-Imports zum Aktivieren (z.B. wasi:cli, wasi:io) |
wasi |
No | WASI-Konfiguration (args, env, mounts) |
limits |
No | Ausfuehrungslimits |
Vorkompilierte WASM-Funktionen
Laden Sie kompilierte .wasm-Binaries aus einem Dateisystem-Eintrag:
entries:
- name: assets
kind: fs.directory
directory: ./wasm
- name: compute
kind: function.wasm
fs: myns:assets
path: /compute.wasm
hash: sha256:292b796376f8b4cc360acf2ea6b82d1084871c3607a079f30b446da8e5c984a4
method: compute
pool:
type: lazy
max_size: 4
WASM-Konfigurationsfelder
| Field | Required | Beschreibung |
|---|---|---|
fs |
Yes | Dateisystem-Entry-ID, die das Binary enthaelt |
path |
Yes | Pfad zur .wasm-Datei innerhalb des Dateisystems |
hash |
Yes | SHA-256-Hash zur Integritaetspruefung (sha256:...) |
method |
Yes | Name der exportierten Funktion, die aufgerufen wird |
wit |
No | WIT-Signatur fuer Raw/Core-Module |
pool |
No | Worker-Pool-Konfiguration |
transport |
No | Input/Output-Mapping (Standard: payload) |
imports |
No | Host-Imports zum Aktivieren |
wasi |
No | WASI-Konfiguration |
limits |
No | Ausfuehrungslimits |
Worker-Pools
Jede WASM-Funktion verwendet einen Pool vorkompilierter Instanzen. Der Pool-Typ steuert Nebenlaeufigkeit und Ressourcenverbrauch.
| Type | Beschreibung |
|---|---|
inline |
Synchron, single-threaded. Neue Instanz pro Aufruf. |
lazy |
Keine Idle-Worker. Skaliert bei Bedarf bis max_size. |
static |
Feste Anzahl von Workern mit Request-Queue. |
adaptive |
Automatisch skalierende elastische Pools. |
Pool-Konfiguration
pool:
type: static
size: 4 # Total pool size
workers: 2 # Worker threads
buffer: 16 # Request queue buffer (default: workers * 64)
pool:
type: lazy
max_size: 8 # Maximum concurrent instances
pool:
type: adaptive
max_size: 16 # Upper scaling bound
warm_start: true # Pre-instantiate initial workers
Das Standard-Maximum fuer elastische Pools betraegt 100 Worker, wenn max_size nicht angegeben ist.
Transports
Transports steuern, wie Input und Output zwischen der Runtime und dem WASM-Modul abgebildet werden.
| Transport | Beschreibung |
|---|---|
payload |
Bildet Runtime-Payloads direkt auf WASM-Aufrufargumente ab (Standard) |
wasi-http |
Bildet HTTP-Request/Response-Kontext auf WASM-Argumente und -Ergebnisse ab |
Payload-Transport
Der Standard-Transport uebergibt Argumente direkt. Lua-Werte werden in Go-Typen transkodiert und dann in WIT-Typen abgesenkt:
- name: compute
kind: function.wasm
fs: myns:assets
path: /compute.wasm
hash: sha256:...
method: compute
pool:
type: inline
-- Arguments passed directly as WASM function parameters
local result, err = funcs.call("myns:compute", 6, 7)
-- result: 42
WASI-HTTP-Transport
Der wasi-http-Transport bildet HTTP-Requests auf WASM ab und schreibt Ergebnisse zurueck in die HTTP-Response. Verwenden Sie ihn, um WASM-Funktionen als HTTP-Endpunkte bereitzustellen:
- name: greet_wasm
kind: function.wasm
fs: myns:assets
path: /greet.wasm
hash: sha256:...
method: greet
transport: wasi-http
pool:
type: inline
- name: greet_endpoint
kind: http.endpoint
method: POST
path: /api/greet
func: greet_wasm
Ausfuehrungslimits
Legen Sie eine maximale Ausfuehrungszeit fuer eine Funktion fest:
limits:
max_execution_ms: 5000 # 5 second timeout
Wenn das Limit ueberschritten wird, wird die Ausfuehrung abgebrochen und ein Fehler zurueckgegeben.
WASI-Konfiguration
Konfigurieren Sie WASI-Faehigkeiten fuer das Guest-Modul:
wasi:
args: ["--verbose"]
cwd: "/app"
env:
- id: myns:api_key
name: API_KEY
required: true
- id: myns:debug_mode
name: DEBUG
mounts:
- fs: myns:data_files
guest: /data
read_only: true
- fs: myns:output
guest: /output
| Field | Beschreibung |
|---|---|
args |
Kommandozeilenargumente, die an den Guest uebergeben werden |
cwd |
Arbeitsverzeichnis innerhalb des Guest (muss absolut sein) |
env |
Umgebungsvariablen, abgebildet aus Registry-Env-Eintraegen |
mounts |
Dateisystem-Mounts aus Registry-Dateisystem-Eintraegen |
Umgebungsvariablen werden zum Aufrufzeitpunkt aus der Umgebungs-Registry aufgeloest. Erforderliche Variablen verursachen einen Fehler, wenn sie nicht gefunden werden.
Mount-Pfade muessen absolut und eindeutig sein. Jeder Mount bildet einen Runtime-Dateisystem-Eintrag auf einen Guest-Verzeichnispfad ab.
Beispiele
Datentransformations-Pipeline
entries:
- name: wasm_binaries
kind: fs.directory
directory: ./wasm
- name: transform_users
kind: function.wasm
fs: myns:wasm_binaries
path: /mapper.wasm
hash: sha256:7304fc7d19778605458ae5804dae9a7343dcd3f5fc22bcc9415e98b5047192dd
method: transform-users
pool:
type: lazy
max_size: 4
- name: filter_active
kind: function.wasm
fs: myns:wasm_binaries
path: /mapper.wasm
hash: sha256:7304fc7d19778605458ae5804dae9a7343dcd3f5fc22bcc9415e98b5047192dd
method: filter-active
pool:
type: lazy
max_size: 4
local funcs = require("funcs")
local users = {
{id = 1, name = "Alice", tags = {"admin", "dev"}, active = true},
{id = 2, name = "Bob", tags = {"user"}, active = false},
{id = 3, name = "Carol", tags = {"dev"}, active = true},
}
-- Transform: adds display field and tag count
local transformed, err = funcs.call("myns:transform_users", users)
-- Filter: returns only active users
local active, err = funcs.call("myns:filter_active", users)
Asynchrones Sleep mit WASI Clocks
WASM-Komponenten, die wasi:clocks und wasi:io importieren, koennen Clocks und Polling verwenden. Der asynchrone Yield-Mechanismus integriert sich in den Wippy-Dispatcher:
- name: sleep_ms
kind: function.wasm
fs: myns:wasm_binaries
path: /sleep_test.wasm
hash: sha256:...
method: "test-sleep#sleep-ms"
imports:
- wasi:io
- wasi:clocks
pool:
type: inline
Der #-Separator im method-Feld referenziert eine Interface-Methode: test-sleep#sleep-ms ruft die Funktion sleep-ms aus dem Interface test-sleep auf.
Siehe auch
- Uebersicht - WebAssembly-Runtime-Uebersicht
- Host-Funktionen - Verfuegbare Host-Schnittstellen
- Prozesse - WASM als Prozesse ausfuehren
- Entry-Typen - Alle Registry Entry Kinds