diff options
author | irina <irinagomez@us.es> | 2014-01-22 13:38:47 +0000 |
---|---|---|
committer | irina <irinagomez@us.es> | 2014-01-22 13:38:47 +0000 |
commit | 0109c07274d4a712f18c820466785f25b2d88c3c (patch) | |
tree | d5cb5f12c172da4d382829a1cfc4b230df327d75 | |
parent | d344ed8094aa522335155939d2be697f930547f9 (diff) |
#565 se crean script: partclone2sync y clean-mountdirimage. Se controla el error al crear la imagen.
git-svn-id: https://opengnsys.es/svn/branches/version1.0@4119 a21b9725-9963-47de-94b9-378ad31fedc9
-rwxr-xr-x | admin/Sources/Services/ogAdmRepoAux | 15 | ||||
-rw-r--r-- | client/shared/etc/lang.ca_ES.conf | 1 | ||||
-rw-r--r-- | client/shared/etc/lang.en_GB.conf | 1 | ||||
-rw-r--r-- | client/shared/etc/lang.es_ES.conf | 1 | ||||
-rwxr-xr-x | server/bin/clean-mountdirimage | 38 | ||||
-rwxr-xr-x | server/bin/createfileimage | 2 | ||||
-rwxr-xr-x | server/bin/partclone2sync | 174 |
7 files changed, 229 insertions, 3 deletions
diff --git a/admin/Sources/Services/ogAdmRepoAux b/admin/Sources/Services/ogAdmRepoAux index 1fc3e770..d6e5dac1 100755 --- a/admin/Sources/Services/ogAdmRepoAux +++ b/admin/Sources/Services/ogAdmRepoAux @@ -31,7 +31,12 @@ KERNEL=$(file $BASEDIR/tftpboot/ogclient/ogvmlinuz |awk -F . '{print $2}') # Añade registro de incidencias. function echolog () { - date +"%Y%m%d-%H%M%S $*" >> $REPOLOG + if [ "$1" == "-o" ]; then + shift + date +"%Y%m%d-%H%M%S $*"|tee -a $REPOLOG + else + date +"%Y%m%d-%H%M%S $*" >> $REPOLOG + fi } function mountImage () { @@ -104,6 +109,7 @@ case "$PARM1" in # Si existe la imagen hacemos copia de seguridad y la redimesionamos if [ -f "$IMGFILE" ]; then + echolog "La imagen $IMGFILE ya existe." # TODO modificar ogGetImageSize IMGSIZE=$(ls -l --block-size=1024 $IMGFILE| cut -f5 -d" ") @@ -161,7 +167,12 @@ case "$PARM1" in fi # Montamos la imagen. mountImage "$IMGFILE" "$DIRMOUNT" - [ "$?" == "0" ] || (echo salida=$?; echolog "Error al crear/redimensionar la imagen"; exit 1) + RETVAL=$? + if [ $RETVAL -ne 0 ]; then + rmdir "$DIRMOUNT" + echolog -o "Error al crear/redimensionar la imagen" + exit $RETVAL + fi touch "$DIRMOUNT/ogimg.info" TIME2=$[SECONDS-TIME] diff --git a/client/shared/etc/lang.ca_ES.conf b/client/shared/etc/lang.ca_ES.conf index 63d2907e..48c03212 100644 --- a/client/shared/etc/lang.ca_ES.conf +++ b/client/shared/etc/lang.ca_ES.conf @@ -202,6 +202,7 @@ MSG_HELP_ogWaitMountImage="Se espera un tiempo estimado a que se monte la imagen MSG_HELP_configureOs="Post-configura de arranque del sistema" MSG_HELP_createBaseImage="Genera imagen basica de la particion" MSG_HELP_createDiffImage="Genera imagen diferencial de la particion respecto a la imagen basica" +MSG_HELP_partclone2sync="Convierte imagen de partclone en imagen sincronizable." MSG_HELP_restoreBaseImage="Restaura una imagen basica en una particion" MSG_HELP_restoreDiffImage="Restaura una imagen diferencial en una particion" MSG_HELP_updateCache="Realiza la actualizacion de la cache" diff --git a/client/shared/etc/lang.en_GB.conf b/client/shared/etc/lang.en_GB.conf index eda6c932..71bc88a6 100644 --- a/client/shared/etc/lang.en_GB.conf +++ b/client/shared/etc/lang.en_GB.conf @@ -202,6 +202,7 @@ MSG_HELP_ogWaitMountImage="Se espera un tiempo estimado a que se monte la imagen MSG_HELP_configureOs="Post-configura de arranque del sistema" MSG_HELP_createBaseImage="Genera imagen basica de la particion" MSG_HELP_createDiffImage="Genera imagen diferencial de la particion respecto a la imagen basica" +MSG_HELP_partclone2sync="Convierte imagen de partclone en imagen sincronizable." MSG_HELP_restoreBaseImage="Restaura una imagen basica en una particion" MSG_HELP_restoreDiffImage="Restaura una imagen diferencial en una particion" MSG_HELP_updateCache="Realiza la actualizacion de la cache" diff --git a/client/shared/etc/lang.es_ES.conf b/client/shared/etc/lang.es_ES.conf index ec092422..bc19362c 100644 --- a/client/shared/etc/lang.es_ES.conf +++ b/client/shared/etc/lang.es_ES.conf @@ -202,6 +202,7 @@ MSG_HELP_ogWaitMountImage="Se espera un tiempo estimado a que se monte la imagen MSG_HELP_configureOs="Post-configura de arranque del sistema" MSG_HELP_createBaseImage="Genera imagen basica de la particion" MSG_HELP_createDiffImage="Genera imagen diferencial de la particion respecto a la imagen basica" +MSG_HELP_partclone2sync="Convierte imagen de partclone en imagen sincronizable." MSG_HELP_restoreBaseImage="Restaura una imagen basica en una particion" MSG_HELP_restoreDiffImage="Restaura una imagen diferencial en una particion" MSG_HELP_updateCache="Realiza la actualizacion de la cache" diff --git a/server/bin/clean-mountdirimage b/server/bin/clean-mountdirimage new file mode 100755 index 00000000..a47861ff --- /dev/null +++ b/server/bin/clean-mountdirimage @@ -0,0 +1,38 @@ +#!/bin/bash +#/** +# clean-mountdirimage +#@brief Borra los directorios de montaje de las imagenes que no se estén usando. +#@param No +#@return Información sobre los directorios borrardos o no. +#@exception # Usuario distinto de root. +#@version 1.0 +#@author Irina Gomez +#@date 2014-01-20 +#*/ ## + +BASEDIR="/opt/opengnsys/images/mount" +DIR=$(ls $BASEDIR) +if [ "$USER" != "root" ]; then + echo "$PROG: Error: solo ejecutable por root" >&2 + exit 1 +fi + +# Desmontamos los directorios que no se esten usando. +umount /opt/opengnsys/images/mount/* &>/dev/null +# Guardamos los directorios que siguen montados. +MOUNTEDDIR=$(df |grep /opt/opengnsys/images/mount) +# Comprobamos que no esta montado y borramos. +echo "Borrando los directorios de montaje de las imagenes:" +for IMGDIR in $DIR +do + echo -n " $IMGDIR:" + if ! echo $MOUNTEDDIR |grep -e "$BASEDIR/$IMGDIR " -e "$BASEDIR/$IMGDIR$" >/dev/null ; then + rm -rf $BASEDIR/$IMGDIR + echo "directorio borrado." + else + echo "directorio ocupado, no se puede borrar." + + fi +done + + diff --git a/server/bin/createfileimage b/server/bin/createfileimage index b4ba405d..73c57711 100755 --- a/server/bin/createfileimage +++ b/server/bin/createfileimage @@ -55,7 +55,7 @@ SIZEREQUIRED=$3 [ $SIZEREQUIRED -lt 300000 ] && SIZEREQUIRED=300000 echo CREATE_IMAGE "$1" $IMGEXT $SIZEREQUIRED -echo -ne CREATE_IMAGE "$1" $IMGEXT $SIZEREQUIRED| /opt/opengnsys/sbin/ogAdmRepoAux +echo -ne CREATE_IMAGE "$1" $IMGEXT $SIZEREQUIRED| /opt/opengnsys/sbin/ogAdmRepoAux || exit $? echo "Los resultado se registran en $REPOLOG. " rm $IMGFILE.lock diff --git a/server/bin/partclone2sync b/server/bin/partclone2sync new file mode 100755 index 00000000..4272cf06 --- /dev/null +++ b/server/bin/partclone2sync @@ -0,0 +1,174 @@ +#!/bin/bash +#/** +# partclone2sync +#@brief Convierte imagen de partclone en imagen sincronizable. +#@param 1 imagen partclone. +#@param 2 imagen sincronizable. +#@param 3 tipo de sincronización y formato de la imagen SYNC1 (directorio) y SYNC2 (fichero) +#@exception OG_ERR_FORMAT # 1 formato incorrecto. +#@exception OG_ERR_NOTFOUND # 2 Fichero o dispositivo no encontrado +#@exception OG_ERR_LOCKED # 4 Imagen de partclone bloqueada. +#@exception OG_ERR_IMAGE # 5 Error al crear la imagen. +#@exception OG_CACHESIZE # 16 No hay espacio suficiente en el disco. +#@note Necesita tener instalado partclone-utils y lzop +#@version 1.0 - +#@author Irina Gomez +#@date 2014-01-22 +#*/ ## +trap "onexit \"$1\" \"$2\" $3" 0 5 16 9 15 + +function onexit() { + local exit_status=$? + # Desmontamos el cliente de opengnsys y la imagen temporal. + umount $OGCLIENTDIR/ogclientmount $AUXDIR + rm -rf $IMGINFO $FILEHEAD $TMPLOG + + # Borramos los ficheros de bloqueo de las imagenes nuevas. + rm -rf $RSYNCIMG.img.lock $AUXIMG.lock + # Borramos los ficheros de bloqueo dela imagen de partclone si no estaba bloqueada. + [ $exit_status -eq 4 ] || rm -rf $PARTCLONEIMG.lock + + # Borramos las imagenes y directorios temporales. + rm $AUXIMG + rmdir $AUXDIR $OGCLIENTDIR/ogclientmount + + exit $exit_status +} + +TIME1=$SECONDS + +BASEDIR=/opt/opengnsys +REPODIR="$BASEDIR/images" +BINDIR="$BASEDIR/bin" +PROG="$(basename $0)" +# Cargamos los mensajes en el idioma del sistema. +source $BASEDIR/client/etc/lang.$LANG.conf + +# Sistema de fichero de la imagen según kernel, menor que 3.7 EXT4. comparamos revision +[ $(uname -r|cut -d. -f2) -lt 7 ] && IMGFS="EXT4" || IMGFS="BTRFS" + +# Mostrar ayuda: Si se solicita, si faltan parametros o $3 no es SYNC1 o SYNC2. +if [ "$*" == "help" -o $# -lt 3 ] && ! [[ "$3" == SYNC[1,2] ]]; then + echo -e "$PROG: $MSG_HELP_partclone2sync \n" \ + "$MSG_FORMAT: $PROG image_partclone image_rsync [ SYNC1 | SYNC2 ] \n" \ + " $PROG Windows7 Windows72013 SYNC1 " + exit 0 +fi + +if [ "$USER" != "root" ]; then + echo "$PROG: Error: solo ejecutable por root" >&2 + exit 1 +fi + + +PARTCLONEIMG="$REPODIR/$1.img" +RSYNCIMG="$REPODIR/$2" +AUXIMG="$REPODIR/$1.tmp.img" +AUXDIR="/tmp/partclone2rsync$$" +TYPE="$3" +TMPLOG=/tmp/rsync$$.sal + +# Comprobamos que exista la imagen. +! [ -f $PARTCLONEIMG ] && echo "$MSG_ERR_NOTFOUND: $1" && exit 2 + +# Comprobamos que la imagen no este bloqueada. +[ -f $PARTCLONEIMG.lock ] && echo "$MSG_ERR_LOCKED: $1" && exit 4 + +# Usamos el partclone del ogclient. +OGCLIENTDIR=$BASEDIR/tftpboot/ogclient +[ -d $OGCLIENTDIR/ogclientmount ] || mkdir $OGCLIENTDIR/ogclientmount +mount $OGCLIENTDIR/ogclient.sqfs $OGCLIENTDIR/ogclientmount +PATHPARTCLONE=$OGCLIENTDIR/ogclientmount/usr/sbin + +# Creamos fichero de bloqueo +touch $PARTCLONEIMG.lock $AUXIMG.lock + + +# Datos imagen. +echo [10] Obtenemos datos del partclone. +FILEHEAD=/tmp/$(basename $PARTCLONEIMG).infohead +COMPRESSOR=`file $PARTCLONEIMG | awk '{print $2}'` +$COMPRESSOR -dc $PARTCLONEIMG 2>/dev/null | head > $FILEHEAD +PARTCLONEINFO=$(LC_ALL=C partclone.info $FILEHEAD 2>&1) +if `echo $PARTCLONEINFO | grep size > /dev/null` +then + FS=$(echo $PARTCLONEINFO | awk '{gsub(/\: /,"\n"); print toupper($8);}') + echo $PARTCLONEINFO | grep GB > /dev/null && SIZEFACTOR=1000000 || SIZEFACTOR=1024 + IMGSIZE=$(echo $PARTCLONEINFO | awk -v FACTOR=$SIZEFACTOR '{gsub(/\: /,"\n"); printf "%d\n", $11*FACTOR;}') +else + echo "Error: partclone.info no detecta la imagen" + exit 5 +fi +[ "$FS" == "NTFS" ] && echo "Error: Todavia no podemos convertir imagenes de Windows" && exit 6 + +# Calculamos el espacio disponible en la particion de opengnsys. +echo -n "[20]$MSG_SCRIPTS_CREATE_SIZE " +for DIR in "/" "/opt" "/opt/opengnsys" "/opt/opengnsys/images" +do + AUXSIZE=$(df|grep $DIR$|awk '{print $3}') + [ "$AUXSIZE" != "" ] && PARTSIZE=$AUXSIZE +done +let REQUIRESIZE=2*$IMGSIZE +if [ $PARTSIZE -lt $REQUIRESIZE ]; then + echo "No hay espacio suficiente para descomprimir y crear la imagen: $REQUIRESIZE." + exit 16 +fi +echo "$REQUIRESIZE $PARTSIZE" + +# Descomprimimos la imagen de partclone. +echo [30] Descomprimimos la imagen de partclone. +$COMPRESSOR -dc $PARTCLONEIMG | $PATHPARTCLONE/partclone.restore -C -s - -O $AUXIMG + +TIME2=$[SECONDS-TIME1] +echo " $MSG_SCRIPTS_TASK_END: $MSG_SCRIPTS_TIME_PARTIAL: $[TIME2/60]m $[TIME2%60]s" + +# Montamos la imagen: +mkdir -p $AUXDIR +mount $AUXIMG $AUXDIR + +# Sincronizamos de la imagen del partclone a la del rsync. +echo "[60] Sincronizamos desde la imagen de partclone a la de rsync." +if [ "$TYPE" == "SYNC1" ]; then + mkdir -p $RSYNCIMG + echo " * Log temporal en: $TMPLOG" + echo rsync -aHAX $AUXDIR/ $RSYNCIMG --- log: $TMPLOG + rsync -aHAXv $AUXDIR/ $RSYNCIMG >> $TMPLOG +TIME3=$[SECONDS-TIME2] +echo " $MSG_SCRIPTS_TASK_END: $MSG_SCRIPTS_TIME_PARTIAL: $[TIME3/60]m $[TIME3%60]s" +else + IMGINFO="/tmp/ogimg.info$$" + IMGDIR="$REPODIR/mount/$(basename $RSYNCIMG)" + # Calculamos el tamaño de la imagen + SIZE=$(df -k|awk -v P="$AUXDIR" '{if ($6==P) print $3}') + # Creo fichero de informacion de la imagen + echo "#$FSIMG:LZO:$FS:$SIZE" > $IMGINFO + # Factor de compresion de la imagen + [ "$FS" == "NTFS" ] && ZFACTOR=120 || ZFACTOR=110 + [ "$FSIMG" == "BTRFS" ] && let ZFACTOR=$ZFACTOR-30 + let SIZE=$SIZE*$ZFACTOR/100 + + # Creamos el fichero de la imagen vacio (queda montado) + echo " * $MSG_HELP_ogCreateFileImage" + $BINDIR/createfileimage $(basename $RSYNCIMG) img $SIZE || exit 5 + touch $RSYNCIMG.img.lock + TIME3=$[SECONDS-TIME2] + echo " $MSG_SCRIPTS_TASK_END: $MSG_SCRIPTS_TIME_PARTIAL: $[TIME3/60]m $[TIME3%60]s" + + # Sincronizo las imagenes antigua y nueva. + echo " * Sincroniza las imagenes antigua y nueva. log temporal en: $TMPLOG" + echo rsync -aHAX $AUXDIR/ $IMGDIR + rsync -aHAXv $AUXDIR/ $IMGDIR >> $TMPLOG + TIME4=$[SECONDS-TIME3] + echo " $MSG_SCRIPTS_TASK_END: $MSG_SCRIPTS_TIME_PARTIAL: $[TIME4/60]m $[TIME4%60]s" + # copiamos el fichero de informacion dentro de la imagen. + mv $IMGINFO $IMGDIR/ogimg.info + # Desmontamos la imagen y la reducimos al minimo. + $BINDIR/unmountimage $(basename $RSYNCIMG) img + echo " * $MSG_HELP_ogReduceImage." + rm $RSYNCIMG.img.lock + $BINDIR/reduceimage $(basename $RSYNCIMG) img + +fi + +TIME=$[SECONDS-TIME1] +echo " $MSG_SCRIPTS_END: $MSG_SCRIPTS_TIME_TOTAL: $[TIME/60]m $[TIME%60]s" |