[COMO] Hacer back-up y enviar por FTP automaticamente (BD-cron-scripts)

Imagen de lezich
0 puntos

Estimado amigos y amigas, por fin pude automatizar el back-up de la Base de datos y que se envie a un servidor fuera del edificio donde me encuentro, de esa forma aseguramos el back-up hasta contra incendios.

En este pequeño tutorial es una guía de como yo lo hice funcionar, y conste que no soy programador, solo utilice el internet y un amigo me ayudo a hacer el primer script (gracias Oscar)

Les voy a comentar lo que haremos, y luego iré detallando como hacerlo.

1- Vamos a crear una carpeta en la computadora local, donde se irán creando y comprimiendo los backups mediante un script (sin borrar de la computadora local)
2- Luego vamos a crear dos scripts, uno servira para hacer el backup y comprimir con la fecha del día (backup.sh), el otro servirá para conectarse y enviar el backup a un servidor de FTP. (enviar.sh)
3- Donde copiar el primer script para que se ejecute automáticamente cada día, y así tener un respaldo diario.

PREPARANDO LA COMPUTADORA

Como estamos hablando de una base de datos postgres, por una cuestión de permisos, todo será realizado por el usuario "postgres".

1- Lo primero que vamos a hacer, es crear la carpeta local donde estarán los backups, para eso;

sudo mkdir/home/backups

le damos la carpeta al usuario postgres

sudo chown postgres -R /home/backups

2- Ahora vamos a crear los scripts, el primero lo llamaremos backup.sh (o como quieran llamarlo), este archivo lo pondremos dentro de la siguiente carpeta, que se ejecutara automáticamente todos los días, /etc/cron.daily/
Para conocer más sobre el uso del Cron, ingresar aquí.

podemos crear el script de la siguiente manera

sudo nano /etc/cron.daily/backup.sh

dentro del archivo escribiremos los datos para que funcione el script que lo pongo a continuación:

#!/bin/sh
USER=postgres
FECHA=`date +%Y-%m-%d`
echo "Haciendo el Backup de la BD"
/usr/bin/pg_dump BD > /home/backups/backup-$FECHA.sql
echo "Comprimiendo el backup"
/bin/tar cvfz /home/backups/backup-$FECHA.tar.gz /home/backups/backup-$FECHA.sql

echo "Enviando el backup al servidor de FTP"
sh /home/backups/enviar.sh

guardamos con ctrl+x
por supuesto, colocamos la información que corresponde dentro del script, si no entienden, más abajo iré detallando el significado de cada parte para que puedan entender y modificarlo según su necesidad.
y ahora le damos los permisos

sudo chown postgres /etc/cron.daily/backup.sh

y le damos los permisos de ejecución

sudo chmod 777 /etc/cron.daily/backup.sh

Listo, ya tenemoshagamos una prueba para ver si ejecuta

sh /etc/cron.daily/backup.sh

una vez comprobado que este haciendo el backup y creando el archivo comprimido ambos con la fecha del día.
¡LISTO EL PRIMER SCRIPT!


Ahora pasaremos a crear el segundo script, que sirve para enviar al servidor de FTP, lo llamaremos enviar.sh

nos cambiamos al usuario postgres para no que todo lo que creemos pertenezca al usuario postgres, para eso tecleamos en la terminal

su - postgres

y con el usuario postgres creamos el archivo enviar.sh de la siguiente manera (o como crean mejor)

nano /home/backups/enviar.sh

ahora copiamos este script

#!/bin/bash

echo "Conectando y autenticando con el servidor de FTP"
FECHA=`date +%Y-%m-%d`
HOST='ftp.servidor.net'
USER='nombre de usuario'
PASSWD='contraseña'
cd /home/backups/
echo "Enviando back-up de la BD"
ftp -n $HOST << END_SCRIPT
quote USER $USER
quote PASS $PASSWD
binary
put backup-$FECHA.tar.gz
quit
END_SCRIPT
echo "Archivo enviado correctamente"
echo "¡Grande GNU/Linux y Ubuntu-es.org.....by lezich!"

guardamos con ctrl+x
como en el script anterior se debe colocar la información que corresponde dentro del script, más abajo detallaré por parte para que entiendan el funcionamiento del script y asi puedan modificarlo según su necesidad.

IMPORTANTE: para crear este script, usted ya debe contar con un usuario cliente de ftp y un servidor para poder configurar el script correctamente

y ahora le damos los permisos de ejecución

chmod +x /home/backups/enviar.sh

podemos ejecutar manualmente para ver si se conecta y envía el archivo.
si comprobamos que envía correctamente, ahora comprobaremos que todo funciona correctamente, para eso vamos a ejecutar

sh /etc/cron.daily/backup.sh

con esto debería hacer todo seguido,

  1. Crear un back-up
  2. Comprimir el back-up
  3. Conectarse al servidor FTP
  4. Enviar el archivo comprimido al servidor de FTP

si todo esto ocurre como debe ser

¡FELICIDADES, HAS AUTOMATIZADO EL BACK-UP Y ENVIANDO A UN SERVIDOR DE FTP!


PASO A DETALLAR EL FUNCIONAMIENTO DE LOS DOS SCRIPTS

1- BACKUP.SH

Este código al inicio es necesario para que GNU/Linux reconozca que es un script

#!/bin/sh

Lo que hacemos aca es, indicar que el usuario "postgres" es el que ejecutará este script, para que no tengamos problemas de permisos.

USER=postgres 

Acá le decimos que a partir de ese momento todo lo que tenga $FECHA, será para colocar el año-mes+día

FECHA=`date +%Y-%m-%d`

Todo lo que tiene "echo" es lo que informa al usuario lo que el script esta haciendo.

echo "Haciendo el Backup de la BD"

Este es el comando de que queremos hacer back-up y a donde, en este caso es una BD postgres e indica el nombre y lugar en la computadora local donde se creará el archivo de back-up.

/usr/bin/pg_dump BD > /home/backups/backup-$FECHA.sql

Todo lo que tiene "echo" es lo que informa al usuario lo que el script esta haciendo.

echo "Comprimiendo el backup"

Con este comando comprimimos el back-up creado, primero se indica donde estará el archivo comprimdo y luego donde esta el archivo a comprimir

/bin/tar cvfz /home/backups/backup-$FECHA.tar.gz /home/backups/backup-$FECHA.sql

Todo lo que tiene "echo" es lo que informa al usuario lo que el script esta haciendo.

echo "Enviando el backup a al servidor de FTP"

este es la orden para comenzar a ejecutar el segundo script, (enviar.sh), en el que se detalle el lugar exacto donde está ese script

sh /home/backups/enviar.sh

esas fueron las explicaciones de todas las parte del script, usted debe cambiar los datos según su propia necesidad.


2- ENVIAR.SH

Este código al inicio es necesario para que GNU/Linux reconozca que es un script

#!/bin/bash

Todo lo que tiene "echo" es lo que informa al usuario lo que el script esta haciendo.

echo "Conectando y autenticando con el servidor de FTP"

Acá le decimos que a partir de ese momento todo lo que tenga $FECHA, será para colocar el año-mes+día

FECHA=`date +%Y-%m-%d`

Acá es donde colocamos los datos que corresponden para poder conectarse, la dirección del servidor (HOST), el usuario (USER) y su contraseña (PASS)

HOST='ftp.servidor.net'
USER='nombre de usuario'
PASSWD='contraseña'

Con este comando le indicamos al programa cual es la carpeta local donde esta el archivo que vamos a enviar al servidor de FTP

cd /home/backups/

Todo lo que tiene "echo" es lo que informa al usuario lo que el script esta haciendo.

echo "Enviando back-up de la BD"

Aca van todos los comandos a ejecutarse cuando ya estamos dentro del programa de FTP

ftp -n $HOST << END_SCRIPT
quote USER $USER
quote PASS $PASSWD
binary

Siguiendo dentro de los comandos del programa de FTP, se ejecuta el comando para enviar el archivo, que es el "put", y para luego desconectarse y serra "quit"

put backup-$FECHA.tar.gz
quit
END_SCRIPT

Todo lo que tiene "echo" es lo que informa al usuario lo que el script esta haciendo.

echo "Archivo enviado correctamente"
echo "¡Grande GNU/Linux y Ubuntu-es.org.....by lezich!"

Y YA ESTA TODO, Y CREO QUE BIEN EXPLICADO

ACTUALIZACIÓN

para todos aquellos que ingresaron antes del 16 de febrero de 2011, les comento que hice una corrección al script "backup.sh", ya que anteriormente creaba el archivo .sq, pero no estaba realmente haciendo el backup, por lo que ahora, con esta modificación ese tema ya lo he resuelto... :)

Imagen de pfledesma
+1
0
-1

Lo primero felicitarte por el maravilloso post, me ha servido de gran ayuda, pero solo tengo un problemilla, que me pide la contraseña del usuario cada vez que se ejecuta el script. Hay alguna solución a esto?
Mi SO es Ubuntu server. Muchas gracias.

+1
0
-1