Servicios
Si no tienes claro qué herramienta usar, consulta rdc vs renet.
Esta página cubre cómo desplegar y gestionar servicios en contenedores: Rediaccfiles, red de servicios, inicio/detención, operaciones masivas e inicio automático.
El Rediaccfile
El Rediaccfile es un script Bash que define cómo se inician y detienen sus servicios. Debe llamarse Rediaccfile o rediaccfile (insensible a mayúsculas) y colocarse dentro del sistema de archivos montado del repositorio.
Los Rediaccfiles se descubren en dos ubicaciones:
- La raíz de la ruta de montaje del repositorio
- Subdirectorios de primer nivel de la ruta de montaje (no recursivo)
Los directorios ocultos (nombres que comienzan con .) se omiten.
Funciones del Ciclo de Vida
Un Rediaccfile contiene hasta dos funciones:
| Función | Cuándo se ejecuta | Propósito | Comportamiento en caso de error |
|---|---|---|---|
up() | Al iniciar | Iniciar servicios (por ejemplo, renet compose -- up -d) | La falla del Rediaccfile raíz es crítica (detiene todo). Las fallas en subdirectorios son no críticas (se registran, continúa al siguiente) |
down() | Al detener | Detener servicios (por ejemplo, renet compose -- down) | Mejor esfuerzo — las fallas se registran pero siempre se intentan todos los Rediaccfiles |
Ambas funciones son opcionales. Si una función no está definida, se omite silenciosamente.
Orden de Ejecución
- Inicio (
up): Primero el Rediaccfile raíz, luego los subdirectorios en orden alfabético (A a Z). - Detención (
down): Subdirectorios en orden alfabético inverso (Z a A), luego el raíz al final.
Variables de Entorno
Cuando se ejecuta una función del Rediaccfile, las siguientes variables de entorno están disponibles:
| Variable | Descripción | Ejemplo |
|---|---|---|
REDIACC_WORKING_DIR | Ruta de montaje del repositorio | /mnt/rediacc/mounts/abc123 |
REDIACC_REPOSITORY | GUID del repositorio | a1b2c3d4-e5f6-... |
REDIACC_NETWORK_ID | ID de red (entero) | 2816 |
DOCKER_HOST | Socket Docker del daemon aislado de este repositorio | unix:///var/run/rediacc/docker-2816.sock |
{SERVICE}_IP | IP de loopback para cada servicio definido en .rediacc.json | POSTGRES_IP=127.0.11.2 |
Las variables {SERVICE}_IP se generan automáticamente a partir de .rediacc.json. La convención de nomenclatura convierte el nombre del servicio a mayúsculas con guiones reemplazados por guiones bajos, y luego agrega _IP. Por ejemplo, listmonk-app se convierte en LISTMONK_APP_IP.
Advertencia: No use
sudo dockeren los Rediaccfiles. El comandosudorestablece las variables de entorno, lo que significa queDOCKER_HOSTse pierde y los comandos de Docker apuntarán al daemon del sistema en lugar del daemon aislado del repositorio. Esto rompe el aislamiento de contenedores y puede causar conflictos de puertos. Rediacc bloqueará la ejecución si detectasudo dockersin-E.Use
renet composeen sus Rediaccfiles — automáticamente gestionaDOCKER_HOST, inyecta etiquetas de red para el descubrimiento de rutas y configura la red de servicios. Consulte Red para detalles sobre cómo se exponen los servicios a través del proxy inverso. Si llama a Docker directamente, usedockersinsudo— las funciones del Rediaccfile ya se ejecutan con privilegios suficientes. Si debe usar sudo, usesudo -E dockerpara preservar las variables de entorno.
Ejemplo
#!/bin/bash
up() {
echo "Starting services..."
renet compose -- up -d
}
down() {
echo "Stopping services..."
renet compose -- down
}
Importante: Use siempre
renet compose --en lugar dedocker compose. El wrapperrenet composeimpone la red del host, la asignación de IP y las etiquetas de descubrimiento de servicios requeridas por renet-proxy. Las capacidades de checkpoint/restauración CRIU se añaden a los contenedores con la etiquetarediacc.checkpoint=true. El uso directo dedocker composees rechazado por la validación del Rediaccfile. Consulte Red para más detalles.
Diseño Multi-Servicio
Para proyectos con múltiples grupos de servicios independientes, use subdirectorios:
/mnt/rediacc/mounts/my-app/
├── Rediaccfile # Raíz: configuración compartida
├── docker-compose.yml
├── database/
│ ├── Rediaccfile # Servicios de base de datos
│ └── docker-compose.yml
├── backend/
│ ├── Rediaccfile # Servidor API
│ └── docker-compose.yml
└── monitoring/
├── Rediaccfile # Prometheus, Grafana, etc.
└── docker-compose.yml
Orden de ejecución para up: raíz, luego backend, database, monitoring (A-Z).
Orden de ejecución para down: monitoring, database, backend, luego raíz (Z-A).
Red de Servicios (.rediacc.json)
Cada repositorio obtiene una subred /26 (64 IPs) en el rango de loopback 127.x.x.x. Los servicios se vinculan a IPs de loopback únicas para que puedan ejecutarse en los mismos puertos sin conflictos.
El Archivo .rediacc.json
Mapea nombres de servicios a números de slot. Cada slot corresponde a una dirección IP única dentro de la subred del repositorio.
{
"services": {
"api": {"slot": 0},
"postgres": {"slot": 1},
"redis": {"slot": 2}
}
}
Generación Automática desde Docker Compose
No necesita crear .rediacc.json manualmente. Cuando ejecuta rdc repo up, Rediacc automáticamente:
- Escanea todos los directorios que contienen un Rediaccfile en busca de archivos compose (
docker-compose.yml,docker-compose.yaml,compose.ymlocompose.yaml) - Extrae los nombres de servicio de la sección
services: - Asigna el siguiente slot disponible a cualquier servicio nuevo
- Guarda el resultado en
{repository}/.rediacc.json
Cálculo de IP
La IP de un servicio se calcula a partir del ID de red del repositorio y el slot del servicio. El ID de red se distribuye entre el segundo, tercer y cuarto octeto de una dirección de loopback 127.x.y.z. Cada servicio recibe un desplazamiento de slot + 2 (los desplazamientos 0 y 1 están reservados).
| Offset | Address | Purpose |
|---|---|---|
| .0 | 127.0.11.0 | Network address (reserved) |
| .1 | 127.0.11.1 | Gateway (reserved) |
| .2 – .62 | 127.0.11.2 – 127.0.11.62 | Services (slot + 2) |
| .63 | 127.0.11.63 | Broadcast (reserved) |
Ejemplo para ID de red 2816 (0x0B00), dirección base 127.0.11.0:
| Servicio | Slot | Dirección IP |
|---|---|---|
| api | 0 | 127.0.11.2 |
| postgres | 1 | 127.0.11.3 |
| redis | 2 | 127.0.11.4 |
Cada repositorio soporta hasta 61 servicios (slots 0 a 60).
Uso de IPs de Servicio en Docker Compose
Dado que cada repositorio ejecuta un daemon Docker aislado, renet compose configura automáticamente network_mode: host para todos los servicios. Vincule los servicios a sus IPs de loopback asignadas:
services:
postgres:
image: postgres:16
environment:
PGDATA: /var/lib/postgresql/data
POSTGRES_PASSWORD: secret
command: -c listen_addresses=${POSTGRES_IP} -c port=5432
api:
image: my-api:latest
environment:
DATABASE_URL: postgresql://postgres:secret@${POSTGRES_IP}:5432/mydb
LISTEN_ADDR: ${API_IP}:8080
Nota: No agregue
network_mode: hostmanualmente,renet composelo inyecta automáticamente. Las políticas de reinicio (p.ej.,restart: always) son seguras de usar, renet las elimina automáticamente para compatibilidad CRIU y el watchdog del router maneja la recuperación de contenedores.
Nota: Los repos fork obtienen rutas automáticas planas:
{service}-{tag}.{machine}.{baseDomain}. Los dominios personalizados se omiten para forks.
Iniciar Servicios
Monte el repositorio e inicie todos los servicios:
rdc repo up --name my-app -m server-1 --mount
| Opción | Descripción |
|---|---|
--mount | Montar el repositorio primero si no está montado |
--skip-router-restart | Omitir el reinicio del servidor de rutas después de la operación |
La secuencia de ejecución es:
- Montar el repositorio cifrado con LUKS (si se especifica
--mount) - Iniciar el daemon Docker aislado
- Generar automáticamente
.rediacc.jsona partir de archivos compose - Ejecutar
up()en todos los Rediaccfiles (orden A-Z)
Detener Servicios
rdc repo down --name my-app -m server-1
| Opción | Descripción |
|---|---|
--unmount | Desmontar el repositorio cifrado después de detener los servicios. Si esto no tiene efecto, use rdc repo unmount por separado. |
--skip-router-restart | Omitir el reinicio del servidor de rutas después de la operación |
La secuencia de ejecución es:
- Ejecutar
down()en todos los Rediaccfiles (orden inverso Z-A, mejor esfuerzo) - Detener el daemon Docker aislado (si se usa
--unmount) - Desmontar y cerrar el volumen cifrado con LUKS (si se usa
--unmount)
Operaciones Masivas
Inicie o detenga todos los repositorios en una máquina a la vez:
rdc repo up -m server-1
| Opción | Descripción |
|---|---|
--include-forks | Incluir repositorios bifurcados |
--mount-only | Solo montar, no iniciar contenedores |
--dry-run | Mostrar lo que se haría |
--parallel | Ejecutar operaciones en paralelo |
--concurrency <n> | Máximo de operaciones concurrentes (predeterminado: 3) |
--skip-router-restart | Omitir el reinicio del servidor de rutas después de la operación |
Inicio Automático al Arranque
Por defecto, los repositorios deben montarse e iniciarse manualmente después de reiniciar el servidor. El inicio automático configura los repositorios para montarse automáticamente, iniciar Docker y ejecutar el up() del Rediaccfile cuando el servidor arranca.
Cómo Funciona
Cuando habilita el inicio automático para un repositorio:
- Se genera un archivo de clave LUKS aleatorio de 256 bytes y se agrega al slot 1 de LUKS del repositorio (el slot 0 permanece como la frase de contraseña del usuario)
- El archivo de clave se almacena en
{datastore}/.credentials/keys/{guid}.keycon permisos0600(solo root) - Se instala un servicio systemd (
rediacc-autostart) que se ejecuta al arranque para montar todos los repositorios habilitados e iniciar sus servicios
Al apagar, el servicio detiene graciosamente todos los servicios (down() del Rediaccfile), detiene los daemons Docker y cierra los volúmenes LUKS.
Nota de seguridad: Habilitar el inicio automático almacena un archivo de clave LUKS en el disco del servidor. Cualquier persona con acceso root al servidor puede montar el repositorio sin la frase de contraseña. Evalúe esto según su modelo de amenazas.
Habilitar
rdc repo autostart enable --name my-app -m server-1
Se le solicitará la frase de contraseña del repositorio.
Habilitar Todos
rdc repo autostart enable -m server-1
Deshabilitar
rdc repo autostart disable --name my-app -m server-1
Esto elimina el archivo de clave y destruye el slot 1 de LUKS.
Listar Estado
rdc repo autostart list -m server-1
Ejemplo Completo
Este ejemplo despliega una aplicación web con PostgreSQL, Redis y un servidor API.
1. Configurar
curl -fsSL https://www.rediacc.com/install.sh | bash
rdc config init --name production --ssh-key ~/.ssh/id_ed25519
rdc config machine add --name prod-1 --ip 203.0.113.50 --user deploy
rdc config machine setup --name prod-1
rdc repo create --name webapp -m prod-1 --size 10G
2. Montar y Preparar
rdc repo mount --name webapp -m prod-1
3. Crear los Archivos de la Aplicación
Dentro del repositorio, cree:
docker-compose.yml:
services:
postgres:
image: postgres:16
volumes:
- ./data/postgres:/var/lib/postgresql/data
environment:
POSTGRES_DB: webapp
POSTGRES_USER: app
POSTGRES_PASSWORD: changeme
command: -c listen_addresses=${POSTGRES_IP} -c port=5432
redis:
image: redis:7-alpine
command: redis-server --bind ${REDIS_IP} --port 6379
api:
image: myregistry/api:latest
environment:
DATABASE_URL: postgresql://app:changeme@${POSTGRES_IP}:5432/webapp
REDIS_URL: redis://${REDIS_IP}:6379
LISTEN_ADDR: ${API_IP}:8080
Rediaccfile:
#!/bin/bash
up() {
mkdir -p data/postgres
renet compose -- up -d
echo "Waiting for PostgreSQL..."
for i in $(seq 1 30); do
if renet compose -- exec postgres pg_isready -q 2>/dev/null; then
echo "PostgreSQL is ready."
return 0
fi
sleep 1
done
echo "Warning: PostgreSQL did not become ready within 30 seconds."
}
down() {
renet compose -- down
}
4. Iniciar
rdc repo up --name webapp -m prod-1
5. Habilitar Inicio Automático
rdc repo autostart enable --name webapp -m prod-1