Quiero guardarlo error
si aparece un error en un archivo. Pero el error no se redirige al archivo.
Recibo el siguiente error y no se redirige al archivo.
mysqldump: Couldn't execute 'SHOW FIELDS FROM `v_comloc`': View 'nextgendev_new.v_comloc' references invalid table(s) or column(s) or function(s) or definer/invoker of view lack rights to use them (1356)
Mi intento
HOST="localhost"
PASS="aaaaa"
LOCAL_DIR="/userBackupDrive/backupDatabases/" #Modified local directory
DAY="`date +%a`"
DATE="`date +%F`"
USER="root"
for db in `mysql -h $HOST -u $USER -p$PASS -e "show databases"`
do
mysqldump --opt --routines --single-transaction -p$PASS -u $USER -h $HOST --databases $db | gzip -9 > $LOCAL_DIR$db.$DAY.sql.gz 2>>/var/log/failedJobs/mysqlCronJob.log
RESULT=$?
if [ $RESULT -eq 0 ] ; then
echo
else
echo "$DATE__ $db backup not successful" >> /var/log/failedJobs/dbError.log
fi
done
Respuesta1
Estabas redirigiendo errores desde gzip
, no desde mysqldupmp
.
Ponga la redirección antes de la tubería, así:
mysqldump --opt --routines --single-transaction -p$PASS -u $USER -h $HOST \
--databases $db 2>>/var/log/failedJobs/mysqlCronJob.log \
| gzip -9 > $LOCAL_DIR$db.$DAY.sql.gz
Respuesta2
Parece que estás intentando redirigir la salida estándar (">") dos veces, lo cual no funciona.
Quizás quieras esto:
mysqldump --opt --routines --single-transaction -p$PASS -u $USER -h $HOST --databases $db 2>/var/log/failedJobs/mysqlCronJob.log | gzip -9 > $LOCAL_DIR$db.$DAY.sql.gz