-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrespaldar.sh
More file actions
68 lines (55 loc) · 2.88 KB
/
respaldar.sh
File metadata and controls
68 lines (55 loc) · 2.88 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#!/bin/bash
set -euo pipefail
# ─── Cargar variables de entorno ──────────────────────────────────────────────
DIR_PROYECTO="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
ENV_ARCHIVO="${DIR_PROYECTO}/.env"
if [ ! -f "${ENV_ARCHIVO}" ]; then
echo "ERROR: No se encontró el archivo .env en ${DIR_PROYECTO}"
exit 1
fi
# shellcheck source=.env
source "${ENV_ARCHIVO}"
# ─── Configuración ────────────────────────────────────────────────────────────
CONTENEDOR_BD="analitica-bd"
DIR_RESPALDOS="${DIR_PROYECTO}/respaldos"
ARCHIVO_LOG="${DIR_RESPALDOS}/respaldos.log"
DIAS_RETENCION_LOCAL=30
# ──────────────────────────────────────────────────────────────────────────────
FECHA=$(date +%Y-%m-%d_%H-%M)
ARCHIVO_RESPALDO="${DIR_RESPALDOS}/arca-analitica_${FECHA}.sql.gz"
mkdir -p "${DIR_RESPALDOS}"
registrar() {
echo "[$(date '+%Y-%m-%d %H:%M:%S')] $1" | tee -a "${ARCHIVO_LOG}"
}
registrar "=== Iniciando respaldo ==="
# Verificar que el contenedor de BD está corriendo
if ! docker ps --format '{{.Names}}' | grep -q "^${CONTENEDOR_BD}$"; then
registrar "ERROR: El contenedor ${CONTENEDOR_BD} no está corriendo."
exit 1
fi
# Crear volcado comprimido de la base de datos
registrar "Creando volcado de la base de datos..."
if docker exec "${CONTENEDOR_BD}" pg_dump -U "${BD_USUARIO}" "${BD_NOMBRE}" | gzip > "${ARCHIVO_RESPALDO}"; then
TAMANIO=$(du -sh "${ARCHIVO_RESPALDO}" | cut -f1)
registrar "Volcado creado: $(basename ${ARCHIVO_RESPALDO}) (${TAMANIO})"
else
registrar "ERROR: Falló el volcado de la base de datos. Abortando."
rm -f "${ARCHIVO_RESPALDO}"
exit 1
fi
# Sincronizar con servidor remoto (conserva historial completo allá)
registrar "Sincronizando con servidor remoto ${RESPALDO_SERVIDOR_REMOTO}..."
if rsync -az -e "ssh -i ${RESPALDO_LLAVE_SSH} -o StrictHostKeyChecking=accept-new" \
"${DIR_RESPALDOS}/" \
"${RESPALDO_USUARIO_REMOTO}@${RESPALDO_SERVIDOR_REMOTO}:${RESPALDO_DIR_REMOTO}/"; then
registrar "Sincronización remota exitosa."
else
registrar "ADVERTENCIA: Falló la sincronización remota. El respaldo local sí quedó guardado."
fi
# Limpiar respaldos locales antiguos (el historial completo queda en el servidor remoto)
ELIMINADOS=$(find "${DIR_RESPALDOS}" -name "*.sql.gz" -mtime +${DIAS_RETENCION_LOCAL} | wc -l)
find "${DIR_RESPALDOS}" -name "*.sql.gz" -mtime +${DIAS_RETENCION_LOCAL} -delete
if [ "${ELIMINADOS}" -gt 0 ]; then
registrar "Limpieza local: ${ELIMINADOS} archivo(s) eliminados (mayores a ${DIAS_RETENCION_LOCAL} días)."
fi
registrar "=== Respaldo completado exitosamente ==="