Backup MySQL Incremental via RSYNC/FTP
Publicado por Fernando Bottega Hallberg (última atualização em 02/07/2012)
[ Hits: 9.597 ]
Homepage: http://hallberg.eti.br
O script funciona utilizando-se do log binário do MySQL para fazer o backup incremental da base de dados, que pode ser feito em intervalos curtos de tempo, e um backup full toda noite ou uma vez por semana.
O script também elimina os log binários mais antigos do que 15 dias da base de dados, para não ficar ocupando espaço em disco, sendo que este log já está no backup.
Baixe o script e configure as informações da base de dados e do ftp, ele criará um backup local do MySQL e sincronizará com o FTP ( arquivos mais antigos do que 30 dias serão apagados do backup local, e ficarão somente no FTP ).
No script tem exemplos de como configurar o crontab para executá-lo, lembre-se de configurar o PATH para o script corretamente.
É necessário que o rsync e o lftp estejam instalados no sistema.
Se tiverem dúvidas, sugestões ou correções, favor postarem!
http://hallberg.eti.br/wp/?p=38
#!/bin/bash ## # MySQL BACKUP SCRIPT # Fernando Hallberg # http://www.hallberg.eti.br # fernando at hallberg dot eti dot br ## # Configure a os dados do banco e certifique-se de habilitar o log binário # EX CRON: # de segunda a sábado 4 vezes no dia realiza o backup do log binário # 30 0,8,12,18 * * 1-6 /usr/sbin/flx-mybkp incremental # domingo de manhã realiza o backup completo da base # 2 0 * * 0 /usr/sbin/flx-mybkp full ## BANCO=MySQL_DB MYSQLUSER=MySQL_USER MYSQLPASS=MySQL_USER_PASSWORD FTPUSER=FTP_USER FTPPASS=FTP_PASSWORD FTPHOST=FTP_HOST FTPDIR= BACKUPDIR=/var/backup mkdir -p $BACKUPDIR mkdir -p $BACKUPDIR/mysql/binlog mkdir -p $BACKUPDIR/mysql/full function diskusage() { MAX=80 LANG=C /bin/df -P | tr -s ' '|cut -d ' ' -f1,5 | grep -v Cap | while read line; do fs=$(echo $line | cut -d ' ' -f1) uso=$(echo $line | cut -d ' ' -f2| cut -d '%' -f1) if [ $uso -gt $MAX ]; then echo "$fs esta $uso% cheio, verifique" fi done } function usage(){ echo $0 [ full | incremental ] } function ftpsync(){ /usr/bin/lftp -e "mirror --log=/tmp/lftp.log -v -R $BACKUPDIR mysqlbackup; bye" -u ${FTPUSER},${FTPPASS} ${FTPHOST} &> /dev/null [ $? -gt 0 ] && echo "LFTP ERROR: $?" && exit } function logsync(){ binlog="`basename $(cat /etc/my.cnf | grep '^log-bin=' | cut -d '=' -f2)`" rsync -q -a /var/lib/mysql/$binlog.[0-9][0-9][0-9][0-9][0-9][0-9] $BACKUPDIR/mysql/binlog [ $? -gt 0 ] && echo "RSYNC ERROR: $?" && exit diskusage } function full(){ /usr/bin/find $BACKUPDIR/mysql -type f -mtime +30 -delete FFILE="${BANCO}-backup-$(date +%Y-%m-%d_%H%M).sql.xz" /usr/bin/mysqldump -u ${MYSQLUSER} -p${MYSQLPASS} \ --opt \ --single-transaction \ --no-autocommit \ --all-databases \ --flush-logs \ --master-data \ --routines | xz -2 -c - > ${BACKUPDIR}/mysql/full/${FFILE}; [ $? -gt 0 ] && echo "MYSQLDUMP ERROR: $?" && exit logsync ftpsync } function incremental(){ /usr/bin/mysql -e 'PURGE BINARY LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 15 DAY);' [ $? -gt 0 ] && echo "MYSQL PURGE LOG BINARY ERROR: $?" && exit /usr/bin/mysqladmin -u ${MYSQLUSER} -p${MYSQLPASS} flush-logs [ $? -gt 0 ] && echo "MYSQLADMIN flush-logs ERROR: $?" && exit logsync ftpsync } case "$1" in 'full' ) full ;; 'incremental') incremental ;; esac
Beckup .tar.gz com Data e Hora
Avisar quando partição estiver 90% ocupada
Atenção a quem posta conteúdo de dicas, scripts e tal (1)
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
pacotes 32 bit no void 64 bit (1)
erro ao clonar repo github (7)
ASRock H310CM-HG4 vs Linux (1)
Como adicionar módulo de saúde da bateria dos notebooks Acer ao kernel... (26)
[Shell Script] Script para desinstalar pacotes desnecessários no OpenSuse
[Shell Script] Script para criar certificados de forma automatizada no OpenVpn
[Shell Script] Conversor de vídeo com opção de legenda
[C/C++] BRT - Bulk Renaming Tool
[Shell Script] Criação de Usuarios , Grupo e instalação do servidor de arquivos samba