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.485 ]
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
MySQL - Script para backup automatizado
PKG Sync v4.0 - utilitário para backup de pacotes DEB baixados
Backup de diretórios do sistema Linux
Nenhum comentário foi encontrado.
Agora temos uma assistente virtual no fórum!!! (247)
Manutenção de sistemas Linux Debian e derivados com apt-get, apt, aptitude e dpkg
Melhorando o tempo de boot do Fedora e outras distribuições
Como instalar as extensões Dash To Dock e Hide Top Bar no Gnome 45/46
Como Atualizar Fedora 39 para 40
Instalar Google Chrome no Debian e derivados
Consertando o erro do Sushi e Wayland no Opensuse Leap 15
Instalar a última versão do PostgreSQL no Lunix mantendo atualizado
Flathub na sua distribuição Linux e comandos básicos de gerenciamento
Impressora Canon Ip 1800 (Drivers) 64 bit (3)
iso de sistema 32 bit em atividade (15)
Como transfiro os pokemons do fire red para o emulador mupen64? (1)