Bootloader
El modulo wippy/bootloader orquesta la inicializacion de la aplicacion descubriendo y ejecutando funciones de bootloader en un orden definido al inicio. Otros modulos del framework (migraciones, encriptacion, refresco de indices) registran bootloaders para ejecutar sus propios pasos de inicializacion.
Configuracion
Agrega el modulo a tu proyecto:
wippy add wippy/bootloader
wippy install
Declara la dependencia y el host de aplicacion requerido:
version: "1.0"
namespace: app
entries:
- name: processes
kind: process.host
lifecycle:
auto_start: true
- name: os_env
kind: env.storage.os
- name: dep.bootloader
kind: ns.dependency
component: wippy/bootloader
version: "*"
parameters:
- name: application_host
value: app:processes
- name: env_storage
value: app:os_env
El bootloader en si se ejecuta como wippy.bootloader:bootloader.service (un process.service con auto_start: true). No se requiere nada mas para activarlo.
Como Funciona
Al inicio el bootloader:
- Descubre cada entrada con
meta.type: bootloaderen el registro. - Las ordena por
meta.orderascendente (la mas baja primero). - Ejecuta cada una secuencialmente como una funcion Lua.
- Se detiene en el primer error que retorna
status = "error". - Reporta los conteos totales / exitosos / fallidos / omitidos al finalizar.
Los bootloaders son autonomos -- cada uno verifica sus propias condiciones, hace su trabajo y reporta un resultado estructurado.
Definir un Bootloader
Un bootloader es cualquier entrada function.lua con meta.type: bootloader:
- name: seed_defaults
kind: function.lua
meta:
type: bootloader
order: 50
description: Seed default rows for a new install
source: file://seed_defaults.lua
method: run
modules:
- logger
imports:
sql: :sql
| Campo | Requerido | Descripcion |
|---|---|---|
meta.type |
Si | Debe ser bootloader |
meta.order |
No | Orden de ejecucion (predeterminado 100); el menor se ejecuta primero |
meta.description |
No | Resumen legible para humanos |
meta.requires |
No | Pistas de dependencia mostradas en los logs |
Contrato de Retorno
El method retorna una tabla que describe el resultado:
local function run()
local ok, err = apply_seed()
if err then
return {
status = "error",
message = "seed failed: " .. tostring(err)
}
end
if not ok then
return {
status = "skipped",
message = "already seeded"
}
end
return {
status = "success",
message = "seeded default rows"
}
end
return { run = run }
| Estado | Significado |
|---|---|
success |
Trabajo completado |
skipped |
Sin operacion (ya hecho, precondicion no cumplida) |
error |
Falla -- detiene la secuencia de arranque |
Un bootloader que lanza un error de Lua se trata como error.
Orden de Ejecucion
Los valores de order mas bajos se ejecutan primero. Reserva ordenes bajos para infraestructura:
| Order | Uso Tipico |
|---|---|
10 |
Secretos y claves de encriptacion (proporcionado por el modulo) |
20 |
Migraciones de esquema (proporcionado por wippy/migration) |
50 |
Sembrado de datos, calentamiento de indices de busqueda |
100 |
Predeterminado -- tareas a nivel de aplicacion |
Cuando dos bootloaders comparten un orden, el orden de ejecucion entre ellos no esta garantizado.
Bootloaders Integrados
Clave de Encriptacion (orden 10)
Genera una ENCRYPTION_KEY de 256 bits y la almacena a traves del env_storage configurado si no hay valor presente. Otros modulos (seguridad, seguimiento de uso) leen esta variable para encriptacion de envoltura. Se omite cuando la variable ya existe.
Bootloader de Migracion (orden 20)
Proporcionado por wippy/migration. Descubre cada entrada con meta.type: migration, las agrupa por meta.target_db y aplica las pendientes. Ver Migraciones.
Observar el Estado de Arranque
El servicio registra una linea por bootloader (SUCCESS, FAILED, SKIPPED) con el ID de entrada, orden y duracion. La linea de resumen final reporta los conteos agregados. Un bootloader fallido aborta el inicio -- la politica de reinicio del supervisor entonces se aplica a bootloader.service.
Ver Tambien
- Migraciones - Bootloader de migracion y DSL
- Supervision - Ciclo de vida del servicio y politica de reinicio
- Vision General del Framework - Uso de modulos del framework