Backup de arquivos e banco de dados com envio de e-mail
Publicado por Perfil removido (última atualização em 20/04/2019)
[ Hits: 4.897 ]
Objetivo do script: realizar um backup sincronizando os arquivos e base de dados de acordo com o dia da semana para um HD externo, enviando um e-mail após concluído, bem como se ocorrer algum erro durante o backup.
Exemplo do crontab:
00 22 * * 1-5 /bin/backup
** Necessário ajustar as variáveis do script.
#!/bin/bash #/bin/backup ## Binários SENDEMAIL="/usr/bin/sendEmail" RSYNC="/usr/bin/rsync" MYSQLDUMP="/usr/bin/mysqldump" GZIP="/bin/gzip" UMOUNT="/bin/umount" MOUNT="/bin/mount" ## Váriaveis SERVER_NAME=`/bin/hostname` DIA_DA_SEMANA=`date '+%A'` DATA=`date "+%d-%m-%Y"` HORA=`date '+%H:%M'` LOG="/var/log/backup/backup-$DATA.log" EXT=`mount|grep /dev/sda1` ## Caminho de origem dos backups ### Caminho da pasta home HOME="/home" ### Caminho da pasta dados DADOS="/dados" ### Caminho da configuração do samba SMB_CONF="/etc/samba/smb.conf" ### Caminho da configuração do mysql MY_CNF="/etc/mysql/my.cnf" ## Caminho do hd externo para ser feito o backup DESTINO="/media/hdexterno/$DIA_DA_SEMANA" MOUNT_POINT="/media/hdexterno" DISPOSITIVO="/dev/sda1" ### Configurações de e-mail EMAIL_PRINCIPAL="email@empresa.com.br" EMAIL_COPIA="email2@empresa.com.br" EMAIL_ENVIO="alerta.empresa@gmail.com" EMAIL_PASSWORD="senha_email" SERVER_EMAIL="smtp.gmail.com:587" function desmontar_hd(){ $UMOUNT -l $MOUNT_POINT if [ $? != 0 ]; then envio_email "Erro ao desmontar o HD de backup - $SERVER_NAME" "Ocorreu um erro ao desmontar o HD de backup, verifique se o HD está funcionando corretamente." exit 1 fi } function envio_email(){ #$1 = Titulo do email #$2 = Mensagem do email ## Verifica o tamanho do LOG gerado if [ `/usr/bin/du $LOG|/usr/bin/cut -f 1` -gt 10000 ] then ## Caso o LOG gerado tiver mais que 10M enviar email sem LOG $SENDEMAIL -f $EMAIL_ENVIO -cc $EMAIL_COPIA -t $EMAIL_PRINCIPAL -u "$1" -m "$2" -s $SERVER_EMAIL -xu $EMAIL_ENVIO -xp $EMAIL_PASSWORD else ## Caso o LOG gerado tiver 10M ou menos enviar o email com LOG $SENDEMAIL -f $EMAIL_ENVIO -cc $EMAIL_COPIA -t $EMAIL_PRINCIPAL -u "$1" -m "$2" -a $LOG -s $SERVER_EMAIL -xu $EMAIL_ENVIO -xp $EMAIL_PASSWORD fi exit 0 } function backup_completo(){ echo "Sincronizando arquivos em $1 para $2 - `date '+%d/%m/%G %H:%M'`" >> $LOG $RSYNC --delete --log-file=$LOG -a $1 $2 } function backup_mysql(){ ## Backup de todas as bases de dados do banco de dados MySQL $MYSQLDUMP -u backup -pSenha_MySQL -x -e -A | $GZIP > $DESTINO/backup.sql.gz } function verifica_erro_backup(){ if [ $? != 0 ]; then envio_email "Erro no backup - $SERVER_NAME" "Ocorreu um erro no backup em $1, verifique se o HD está funcionando corretamente." desmontar_hd exit 1 fi } function montar_hd(){ if [ -z "$EXT" ]; then ##Montagem do HD externo $MOUNT $DISPOSITIVO $MOUNT_POINT ## Caso ocorra falha na montagem, enviar um e-mail avisando if [ $? != 0 ]; then echo "Ocorreu um erro ao montar o HD de backup, verifique se o HD está funcionando corretamente" >> $LOG envio_email "Erro ao montar o HD de backup - $SERVER_NAME" "Erro no HD de backup, verifique o LOG." ## Finaliza o script com erros exit 1 fi fi } echo "Iniciando os procedimentos de backup - `date '+%d/%m/%G %H:%M'`" >> $LOG ## Monta o HD se o mesmo estiver disponivel montar_hd ## Backup do diretório /home backup_completo $HOME $DESTINO verifica_erro_backup $HOME ## Backup do diretório /dados backup_completo $DADOS $DESTINO verifica_erro_backup $DADOS ## Backup da configuração do samba backup_completo $SMB_CONF $DESTINO verifica_erro_backup $SMB_CONF ## Backup da configuração do mysql backup_completo $MY_CNF $DESTINO verifica_erro_backup $MY_CNF ## Backup de todas as bases de dados mysql backup_mysql verifica_erro_backup "Banco de dados - base de dados MySQL" desmontar_hd echo "Backup finalizado - `date '+%d/%m/%G %H:%M'`" >> $LOG envio_email "Backup realizado com sucesso - $SERVER_NAME" "O backup foi realizado com com sucesso." ## Finaliza o script com sucesso exit 0
BTRFS - Gerenciamento de snapshot por quantidade
Backup utilizando rsync com envio do log e informativo via e-mail
Nenhum coment�rio foi encontrado.
Aprenda a Gerenciar Permissões de Arquivos no Linux
Como transformar um áudio em vídeo com efeito de forma de onda (wave form)
Como aprovar Pull Requests em seu repositório Github via linha de comando
Visualizar arquivos em formato markdown (ex.: README.md) pelo terminal
Dando - teoricamente - um gás no Gnome-Shell do Arch Linux
Como instalar o Google Cloud CLI no Ubuntu/Debian
Mantenha seu Sistema Leve e Rápido com a Limpeza do APT!
Procurando vídeos de YouTube pelo terminal e assistindo via mpv (2025)
Alguém já usou o framework Avalonia para desenvolver interfaces de usu... (4)
Ajuda Pra Melhoria do NFTABLES. (8)
Sinto uma leve lentidão ao arrastar, miniminizar e restauras as janela... (2)
Pastas da raiz foram para a área de trabalho [RESOLVIDO] (7)