---Script-Backup-Database-MySQL --Th14go--
Script para backup de várias databases MySQL do mesmo servidor,o script contem informações em todo seu escopo, o backup é executado, utilizando o mysqldumb do próprio MySQL, após correr o backup de todas as databases, é iniciado o processo de compactação.É gerado LOG de backup e compactação, para auditoria de execução do script posteriormente, fique a vontade de dar dicas e melhorar o script !
Vamos preparar todo o ambiente antes de executar o script
- Configuração para enviar log por e-mail
- Rotina de Backup
- Validar váriaveis do script
- Enviando database para cloud Mega.nz
- Backup Somente Dados sem Estrutura Database
- Ignorar Table em Backup
1.Configuração para enviar log por e-mail
sudo apt-get install mutt
Editar Arquivo de Configuração
nano ~/.muttrc
Colar parâmetros abaixo.
#Nome do Remetente#
set realname="Backup por e-mail"
#Email do Remetente#
set from="seuemail@gmail.com;"
#Usuario da conta de email#
set my_user=seuemail@gmail.com
#Senha da conta de email#
set my_pass='senhaemail'
#Autenticacao no servidor smtp de email, nesse caso do gmail.com#
set smtp_url=smtps://$my_user:$my_pass@smtp.gmail.com
#Camada de segurança, requerida pelo gmail.com#
set ssl_force_tls = yes
2.Rotina de Backup - Crontab
root@th14golop35:~$ crontab -e # Inicia tarefa com o agendador de tarefas crontab, em "root"
00 19 * * * /bck-mysql.sh #Backup será executado todos os dias as 19:00hr
Para garantir renicie o serviço do crontab
service crontab restart
3.Editar Váriaveis do arquivo bck-mysql.sh
#Variáveis para SQL dos BCK
#Variáveis do MySQL#
#Databases#
- Configurar Mega.nz para envio de database para cloud
Instalar MegaCMD conforme distro. clique aqui
Comandos Mega
mega-login emailcadastrado@gmail.com suasenha
mega-put arquivo.txt /diretorioMega -- Enviar Arquivos
mega-rm arquivo.txt /diretorioMega --Excluir Arquivos
-
Se você optar para que o backup seja feito somente com dados acrescente o comando "--no-create-info" no final da linha do dump ficando assim:
Ex: mysqldump --routines --triggers -h $HOST -u $USER -p$PASSWORD $DATABASEI --no-create-info > $BASEI -
Comando para ignorar table em Backup faça uma variavel para armazenar o valor da database.table
ex: ignore=database.table1
ex: mysqldump --routines --triggers -h $HOST -u $USER -p$PASSWORD $DATABASEI --no-create-info --ignore-table=$ignore > $BASEI
---Script-Backup-Database-MySQL --Th14go--
Script to backup multiple MySQL databases,the script contains information throughout its scope, the backup is performed using mysqldumb from the MySQL itself, after running the backup of all databases, the compression process starts.Backup and compression LOG is generated for auditing the script afterwards, feel free to give tips and improve the script!
Let's prepare the whole environment before running the script
- Configuration to send log by email
- Backup routine
- Validate script variants
- Config Mega.nz send file to Cloud
1.Configuration to send log by email
sudo apt-get install mutt
Edit Configuration File
nano ~ / .muttrc
Paste parameters below.
#Sender Name
set realname = "E-mail Backup"
#Sender Email
set from = "seuemail@gmail.com;"
#Email account user
set my_user=seuemail@gmail.com
#Email account password
set my_pass = 'passwordemail'
#Authentication on smtp mail server, in this case gmail.com
set smtp_url = smtps: // $ my_user: $my_pass@smtp.gmail.com
#Security layer required by gmail.com
set ssl_force_tls = yes
2.Backup routine - Crontab
root @ th14golop35: ~ $ crontab -e # Start task with crontab task scheduler, under "root"
00 19 * * * /bck-mysql.sh #Backup will run every day at 7:00 pm
To ensure restart the crontab service
service crontab restart
3.Editing Bck-mysql.sh File Variables
#BCK SQL Variables#
#MySQL Variables#
#Databases#
- Config Mega.nz to send file Cloud
Install MegaCMDClick Here
Command Mega
mega-login emailregister@gmail.com password
mega-put file.txt /path/toMega -- Send File
mega-rm arquivo.txt /path/ToMega --Delete File
How to use.
#./bck-mysql.sh ou sh bck-mysql.sh