Como crear una tarea programada de respaldo automático de BBDD MySQL



MySQL es un sistema de gestión de bases de datos relacional, es un software de código abierto, licenciado bajo la GPL de la GNU, es muy robusta y rápida, posee gran cantidad de tipos de datos, puede trabajar en distintas plataformas y sistemas operativos; cada base de datos cuenta con 3 archivos:

  • Estructura
  • Datos
  • Índice

Soporta hasta 32 índices por tabla, también aprovecha la potencia de sistemas multiproceso, gracias a su implementación multhilo, por último posee un sistema flexible de contraseñas y gestión de usuarios, con un muy buen nivel de seguridad en los datos.

Planteamiento del problema Duro:

Generar un backup diario de una BBDD en especifico; así mismo se deben de eliminar los backups cuya anterioridad en el servidor es más de 30 días.

Sistema Operativo de referencia:

Usaremos Ubuntu Server, una distribución de Linux basada en Debian.

Solución:

1. Configurar el sistema de fecha y hora del sistema operativo.

Para configurar la fecha y hora del sistema operativo, primero tenemos que averigurar la zona horaria en la que nos encontramos, si vives en Lima, Perú, la zona de tiempo es America/Lima, podemos darnos cuenta del Time Zone de nuestro servidor con el siguiente comando:
timedatectl
Posteriormente a ello listamos todas las zonas de tiempo disponibles en el sistema operativo.
timedatectl list-timezones | grep -i america
Establecemos la zona de tiempo America/Lima por defecto
timedatectl set-timezone America/Lima
Comprobamos
date
Debería de mostrar algo similar al siguiente texto
Sun Jun 14 01:45:17 -05 2020

2. Crear directorio donde guardaremos todos nuestros scripts basheros.

En nuestro ejemplo, usaremos el siguiente directorio "/opt/jobs"
mkdir /opt/jobs

3. Crear carpeta donde se guardará los backups.

En nuestro ejemplo, usaremos el siguiente directorio "/data/backups"
mkdir /data && mkdir /data/backups

4. Crear y configurar el script bashero de respaldo de BBDD MySQL.

Creamos nuestro archivo bashero
touch /opt/jobs/backupDb.sh
Editamos
vim /opt/jobs/backupDb.sh
Ponemos el siguiente script
#!/bin/sh

datetime=`date +%Y%m%d%H%M%S`

mysqldump -u root -p[password] [database] > /data/backups/[database]_$datetime.sql
Otorgamos permisos de ejecución
chmod a+x /opt/jobs/backupDb.sh

5. Crear script bashero que eliminará los backups cuya anterioridad en el servidor es más de 30 días. 

Creamos nuestro archivo bashero
touch /opt/jobs/deleteBackups.sh
Editamos
vim /opt/jobs/deleteBackups.sh
Ponemos el siguiente script
#!/bin/sh

find /data/backups -mtime +30 -type f -name "*.sql" -exec rm {} \;
Otorgamos permisos de ejecución
chmod a+x /opt/jobs/deleteBackups.sh

6. Editar crontab file donde configuraremos las tareas programadas.

Esta configuración es muy importante puesto que nos ayudará con los periodos en los que se debe de ejecutar nuestros scripts, aquí subyace la escencia de la creación de las tareas programadas.

Editamos
crontab -e
Configuramos los periodos de ejecución
# Edit this file to introduce tasks to be run by cron.
# 
# Each task to run has to be defined through a single line
# indicating with different fields when the task will be run
# and what command to run for the task
# 
# To define the time you can provide concrete values for
# minute (m), hour (h), day of month (dom), month (mon),
# and day of week (dow) or use '*' in these fields (for 'any').#      
# Notice that tasks will be started based on the cron's system        
# daemon's notion of time and timezones.
# 
# Output of the crontab jobs (including errors) is sent through       
# email to the user the crontab file belongs to (unless redirected).  
# 
# For example, you can run a backup of all your user accounts
# at 5 a.m every week with:
# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
# 
# For more information see the manual pages of crontab(5) and cron(8) 
# 
# m h dom mon dow   command
  0 5 *   *   *     /opt/jobs/backupDb.sh 
  @monthly          /opt/jobs/deleteBackups.sh
Bueno espero que este tutorial les haya servido de ayuda ya que también toca aspectos que a veces se omite por desconocimiento, como la configuración de la zona de tiempo y el no estar acumulando por mucho tiempo los backups.
Si te gustó compártelo, gracias.