247 lines
9.9 KiB
Bash
247 lines
9.9 KiB
Bash
#!/bin/bash
|
|
#/**
|
|
#@file deployImage
|
|
#@brief Proceso completo de despliegue de imagen, incluyendo actualización de la caché, restauración y post-configuración (este script es llamado por la interfaz RestaurarImagen).
|
|
#@param $1 Repositorio (CACHE, REPO o dirección IP)
|
|
#@param $2 Nombre canónico de la imagen (sin extensión)
|
|
#@param $3 Número de disco
|
|
#@param $4 Número de particion
|
|
#@param $5 Protocolo (UNICAST, por defecto, MULTICAST o TORRENT)
|
|
#@param $6 Opciones del protocolo
|
|
#@exception OG_ERR_FORMAT 1 formato incorrecto.
|
|
#@exception OG_ERR_NOTFOUND 2 fichero de imagen o partición no detectados.
|
|
#@exception OG_ERR_PARTITION 3 # Error en partición de disco.
|
|
#@exception OG_ERR_LOCKED 4 partición bloqueada por otra operación.
|
|
#@exception OG_ERR_IMAGE 5 error al restaurar la imagen del sistema.
|
|
#@exception OG_ERR_IMGSIZEPARTITION 30 Tamaño de la particion es menor al tamaño de la imagen.
|
|
#@exception OG_ERR_NOTCACHE No existe cache -15-
|
|
#@exception OG_ERR_CACHESIZE Tamaño de la paticion menor al archivo a descargar -16-
|
|
#@version 1.0.1 - Separación en protocolos de transferencia y postconfiguracion
|
|
#@author Antonio J. Doblas Viso. Universidad de Málaga
|
|
#@date 2011-05-11
|
|
#@version 1.0.1 - Separación de los ficheros-log para ser gestionado por el httpd-log
|
|
#@author Antonio J. Doblas Viso. Universidad de Málaga
|
|
#@date 2011-05-11
|
|
#@version 1.0.2 - Logica basada en fichero de configuracion engine.cfg
|
|
#@author Antonio J. Doblas Viso. Universidad de Málaga
|
|
#@date 2012-01-11
|
|
#@version 1.0.5 - Renominación del script como "deployImage".
|
|
#@author Antonio J. Doblas Viso y Ramón M. Gómez.
|
|
#@date 2013-12-04
|
|
#@version 1.0.6 - Se añade la gestión de errores de la CACHE cuando en el engine.cfg se define RESTOREPROTOCOLNOCACHE=NONE.
|
|
#@author Antonio J. Doblas Viso.
|
|
#@date 2015-02-23
|
|
#@version 1.1 - Cambio de repositorio para el recurso remoto images si es necesario
|
|
#@author Irina Gomez, ETSII Universidad de Sevilla
|
|
#@date 2015-06-16
|
|
#@version 1.1 - Control de errores en transferencia multicast (ticket #781)
|
|
#@author Irina Gomez, ETSII Universidad de Sevilla
|
|
#@date 2017/04/20
|
|
#**/
|
|
|
|
|
|
#Descripcion:
|
|
# Si Repositorio es el global (REPO) realiza un deploy.
|
|
# Si Repositorio es local (CACHE) realiza un restoreImage CACHE
|
|
# El deploy, si detecta que el cliente no tiene una CACHE o no tiene espacio suficiente consulta el engine.cfg RESTOREPROTOCOLNOCACHE
|
|
|
|
|
|
|
|
PROG="$(basename $0)"
|
|
if [ $# -lt 4 ]; then
|
|
ogRaiseError session $OG_ERR_FORMAT "$MSG_FORMAT: $PROG REPO imagen ndisco nparticion [ UNICAST-DIRECT|UNICAST|UNICAST-CACHE|MULTICAST-DIRECT|MULTICAST|MULTICAST-CACHE|TORRENT [opciones protocolo] ]"
|
|
exit $?
|
|
fi
|
|
|
|
# Asignación de variables (repositorio y protocolo se convierten a mayúsculas).
|
|
TIME1=$SECONDS
|
|
REPO="${1^^}"
|
|
REPO=${REPO:-"REPO"}
|
|
IMGNAME="$2"
|
|
DISK="$3"
|
|
PART="$4"
|
|
PROTO="${5^^}"
|
|
PROTO="${PROTO:-"UNICAST"}"
|
|
PROTOOPT="$6"
|
|
# Unidad organizativa.
|
|
[ "$ogunit" != "" ] && OGUNIT="$ogunit"
|
|
|
|
#Load engine configurator from engine.cfg file.
|
|
#Carga el configurador del engine desde el fichero engine.cfg
|
|
[ -z $OGENGINECONFIGURATE ] && source /opt/opengnsys/etc/engine.cfg
|
|
|
|
# Clear temporary file used as log track by httpdlog
|
|
# Limpia los ficheros temporales usados como log de seguimiento para httpdlog
|
|
echo " " > $OGLOGCOMMAND
|
|
[ "$(ogGetCaller)" == "EjecutarScript" ] || echo -n "" > $OGLOGSESSION
|
|
|
|
# Registro de inicio de ejecución
|
|
ogEcho log session "[1] $MSG_SCRIPTS_START $0 $*"
|
|
|
|
# Si el origen(pariticion) esta bloqueada salir.
|
|
ogIsLocked $DISK $PART && exit $(ogRaiseError session $OG_ERR_LOCKED "$MSG_PARTITION, $DISK $PART"; echo $?)
|
|
|
|
ogEcho log session "$MSG_HELP_ogUnmount $DISK $PART"
|
|
ogUnmount $DISK $PART 2>/dev/null
|
|
|
|
# Valor por defecto para el repositorio.
|
|
if [ "$REPO" == "$(ogGetIpAddress)" -o "$REPO" == "CACHE" ]; then
|
|
MODE="CACHE"
|
|
else
|
|
ogCheckIpAddress "$REPO"
|
|
if [ $? == 0 -o "$REPO" == "REPO" ]; then
|
|
# Si falla el cambio -> salimos con error repositorio no valido
|
|
ogChangeRepo $REPO ${OGUNIT} || exit $(ogRaiseError $OG_ERR_NOTFOUND "$REPO $OGUNIT"; echo $?)
|
|
MODE="REPO"
|
|
fi
|
|
fi
|
|
|
|
#Informacioin previa de la imagen
|
|
IMGOS=$(ogGetImageInfo `ogGetPath $MODE $IMGNAME.img`)
|
|
case $? in
|
|
0) ;;
|
|
1) ogRaiseError session $OG_ERR_NOTFOUND "$REPO $2" || exit $? ;;
|
|
5) ogRaiseError session $OG_ERR_IMAGEFILE "$REPO $2" || exit $? ;;
|
|
*) ogRaiseError session $OG_ERR_GENERIC || exit $? ;;
|
|
esac
|
|
IMGSIZE=$(ls -s `ogGetPath $MODE $IMGNAME.img`| cut -f1 -d" ")
|
|
|
|
ogEcho log session "[1] REPO=$REPO IMG-FILE=$IMGNAME.img SIZE=$IMGSIZE (KB) METADATA=$IMGOS"
|
|
|
|
# Procesar repositorio.
|
|
case "$MODE" in
|
|
CACHE) # Repositorio en caché local.
|
|
NEXTOPERATION=CACHE
|
|
;;
|
|
REPO) # Repositorio remoto por defecto.
|
|
case "$PROTO" in
|
|
MULTICAST-DIRECT)
|
|
NEXTOPERATION=MULTICAST
|
|
;;
|
|
UNICAST-DIRECT)
|
|
NEXTOPERATION=UNICAST
|
|
;;
|
|
|
|
# Si protocolo es torrent|torrent-cache o multicast|multicast-cache
|
|
TORRENT|TORRENT-CACHE|MULTICAST|MULTICAST-CACHE|UNICAST|UNICAST-CACHE)
|
|
# Eliminamos CACHE o DIRECT
|
|
PROTO=${PROTO%%-*}
|
|
ogEcho log session "[2] updateCache "$REPO" \"/$IMGNAME.img\" $PROTO $PROTOOPT"
|
|
TIME2=$SECONDS
|
|
updateCache "$REPO" "/$IMGNAME.img" "$PROTO" "$PROTOOPT"
|
|
RETVAL=$?
|
|
TIME2=$[SECONDS-TIME2]
|
|
ogEcho log session " [ ] $MSG_SCRIPTS_TIME_PARTIAL updateCache $[TIME2/60]m $[TIME2%60]s"
|
|
case $RETVAL in
|
|
0)
|
|
ogEcho log session "[50] updateCache (OK)"
|
|
NEXTOPERATION=CACHE
|
|
;;
|
|
15|16)
|
|
# no se permite usar la cache (no existe(15) o no espacio sufiente (16). Se consulta engine.cfg para RESTOREPROTOCOLNOCACHE [ multicast unicast none ]
|
|
ogEcho log session "[50] $MSG_ERR_NOTCACHE ; $MSG_ERR_CACHESIZE "
|
|
ogEcho log session "[50] $MSG_SCRIPTS_CHECK_ENGINE: RESTOREPROTOCOLNOTCACHE=$RESTOREPROTOCOLNOTCACHE "
|
|
case "$RESTOREPROTOCOLNOTCACHE" in
|
|
MULTICAST)
|
|
case "$PROTO" in
|
|
MULTICAST) NEXTOPERATION=MULTICAST ;;
|
|
TORRENT) NEXTOPERATION=UNICAST ;;
|
|
UNICAST) NEXTOPERATION=UNICAST ;;
|
|
esac
|
|
;;
|
|
UNICAST)
|
|
NEXTOPERATION=UNICAST
|
|
;;
|
|
NONE)
|
|
case $RETVAL in
|
|
15)
|
|
ogEcho log session "[100] $MSG_ERR_NOTCACHE"
|
|
ogRaiseError session $OG_ERR_NOTCACHE "NOT CACHE"
|
|
exit $?
|
|
;;
|
|
16)
|
|
ogEcho log session "[100] $MSG_ERR_CACHESIZE "
|
|
ogRaiseError session $OG_ERR_CACHESIZE "CACHE FULL"
|
|
exit $?
|
|
;;
|
|
esac # del segundo RETAVAL
|
|
;;
|
|
esac # del RESTOREPROTOCOLNOTCACHE
|
|
;;
|
|
57|60)
|
|
# Time-out en la transferencia multicast (El mensaje de error está enviado)
|
|
exit $RETVAL
|
|
;;
|
|
*)
|
|
# Error desconocido
|
|
exit $RETVAL
|
|
;;
|
|
esac
|
|
;;
|
|
*) # Error: protocolo desconocido.
|
|
ogRaiseError session $OG_ERR_FORMAT "$MSG_ERR_FORMAT, $PROTO"
|
|
exit $?
|
|
;;
|
|
esac
|
|
;;
|
|
*) # Error: repositorio desconocido.
|
|
ogRaiseError session $OG_ERR_FORMAT "$MSG_ERR_FORMAT, $REPO"
|
|
exit $?
|
|
;;
|
|
esac
|
|
|
|
TIME3=$SECONDS
|
|
|
|
# Obtener parámetros de restauración.
|
|
case "$NEXTOPERATION" in
|
|
CACHE)
|
|
PARAMS="CACHE $IMGNAME $DISK $PART" ;;
|
|
UNICAST)
|
|
PARAMS="$REPO $IMGNAME $DISK $PART" ;;
|
|
MULTICAST)
|
|
PARAMS="$REPO $IMGNAME $DISK $PART $PROTO $PROTOOPT" ;;
|
|
esac
|
|
|
|
# Si existe, ejecuta script personalizado "restoreImageCustom"; si no, llama al genérico "restoreImage".
|
|
if which restoreImageCustom &>/dev/null; then
|
|
ogEcho log session "[55] $MSG_HELP_ogRestoreImage: restoreImageCustom $PARAMS"
|
|
restoreImageCustom $PARAMS
|
|
else
|
|
ogEcho log session "[55] $MSG_HELP_ogRestoreImage: restoreImage $PARAMS"
|
|
restoreImage $PARAMS
|
|
fi
|
|
RETVAL=$?
|
|
|
|
# Mostrar resultados.
|
|
RESUMERESTOREIMAGE=$(grep -m 1 "Total Time:" $OGLOGCOMMAND)
|
|
ogEcho log session " [ ] $RESUMERESTOREIMAGE "
|
|
# Si la transferencia ha dado error me salgo.
|
|
if [ $RETVAL -ne 0 ] ; then
|
|
ogRaiseError session $OG_ERR_IMAGE "$REPO $IMGNAME" 2>&1
|
|
# Muestro registro de fin de ejecución si no viene de Ejecutar Script
|
|
[ "$(ogGetCaller)" == "EjecutarScript" ] || ogEcho log session "$MSG_INTERFACE_END $OG_ERR_IMAGE"
|
|
exit $OG_ERR_IMAGE
|
|
fi
|
|
TIME3=$[SECONDS-TIME3]
|
|
ogEcho log session " [ ] $MSG_SCRIPTS_TIME_PARTIAL : $[TIME3/60]m $[TIME3%60]s"
|
|
|
|
# Si existe, ejecuta script personalizado de postconfiguración "configureOsCustom"; si no, llama al genérico "configureOs".
|
|
if which configureOsCustom &>/dev/null; then
|
|
ogEcho log session "[90] configureOsCustom"
|
|
configureOsCustom "$DISK" "$PART" "$REPO" "$IMGNAME"
|
|
else
|
|
ogEcho log session "[90] $MSG_SCRIPTS_OS_CONFIGURE "
|
|
configureOs "$DISK" "$PART"
|
|
fi
|
|
|
|
TIME=$[SECONDS-TIME1]
|
|
ogEcho log session "[100] $MSG_SCRIPTS_TIME_TOTAL $[TIME/60]m $[TIME%60]s"
|
|
|
|
# Registro de fin de ejecución
|
|
# Si se ha llamado desde ejecutar script no lo muestro para no repetir.
|
|
if [ "$(ogGetCaller)" != "EjecutarScript" ] ; then
|
|
ogEcho log session "$MSG_INTERFACE_END $RETVAL"
|
|
exit $RETVAL
|
|
fi
|
|
|