a06946e410
Nuevas funciones infra para deploy sin Docker: generación de units systemd (pura), instalación/restart/status de servicios remotos via SSH, setup inicial de VPS (crear dirs, usuario, permisos), y pipelines de deploy completo (setup_vps_app, deploy_app_remote). Incluye tipo DeployConfig con la configuración de deploy por app.
1.4 KiB
1.4 KiB
name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, params, output, tested, tests, test_file_path, file_path
| name | kind | lang | domain | version | purity | signature | description | tags | uses_functions | uses_types | returns | returns_optional | error_type | imports | params | output | tested | tests | test_file_path | file_path | ||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| systemd_status | function | go | infra | 1.0.0 | impure | func SystemdStatus(conn SSHConn, unitName string, logLines int) (SystemdServiceStatus, error) | Consulta el estado de un servicio systemd en un host remoto. Retorna estado activo, sub-estado, PID y logs recientes. |
|
|
|
false | error_go_core |
|
|
SystemdServiceStatus con Active, SubState, MainPID y Logs del servicio | false | functions/infra/systemd_status.go |
Ejemplo
conn := SSHConn{Host: "192.168.1.100", User: "deploy"}
s, err := SystemdStatus(conn, "dag_engine", 20)
if err != nil {
log.Fatal(err)
}
fmt.Printf("State: %s/%s PID: %s\n", s.Active, s.SubState, s.MainPID)
fmt.Println(s.Logs)
Notas
Usa systemctl show para obtener propiedades sin formato humano. Los logs se obtienen con journalctl y son opcionales (logLines=0 los omite). Si journalctl falla (ej: permisos), los logs quedan vacíos sin error.