Backup automatizado de toda a base MySQL
Publicado por Mauricio Sousa (última atualização em 26/01/2015)
[ Hits: 9.259 ]
Funções do script:
- Busca em cada execução todos os bancos da base local, assegurando que nenhum banco novo fique esquecido de fazer backup.
- Comprime os arquivo no formato "bz2" e os salva no diretório "/var/backups/mysql", podendo ser alterado no script.
- Cria para cada banco um diretório com o nome do mesmo, facilitando a localização e identificação dos arquivos.
- Mantém os backups dos últimos 7 dias, removendo os mais antigos.
- A rotina de limpeza sempre checa se existe pelo menos um arquivo de backup, caso só exista um, mesmo que tenha mais de 7 dias é preservado, assegurando que se por algum motivo os backups não tenham sido feitos nos últimos dias, a rotina de limpeza não remova todos.
Para que o script seja executado diariamente de forma automática deve ser adicionada a linha de execução ao crontab do usuário root. Na máquina que roda o serviço MySQL execute os comandos abaixo:
$ sudo su
# chmod +x /root/mysql-backup.py
# crontab -e
Adicione as linhas abaixo, o script será executado diariamente às duas da manhã:
0 2 * * * /root/mysql-backup.py >> /tmp/mysql-backup.log
Espero ter ajudado.
Abraços...
#! /usr/bin/python # -*- coding: utf-8 -*- import os, time, subprocess from ConfigParser import ConfigParser #author="Maurício Sousa" config = ConfigParser() # em Debian, /etc/mysql/debian.cnf contem 'root' login and password. config.read("/etc/mysql/debian.cnf") username = config.get('client', 'user') password = config.get('client', 'password') hostname = config.get('client', 'host') date = time.strftime('%Y-%m-%d-%H:%M') # diretorio de armazenamento dos backups dest = "/var/backups/mysql" def clear(directory): number_of_files = len([item for item in os.listdir(directory) if os.path.isfile(os.path.join(directory, item))]) if number_of_files > 1: print "% s - Foram encontrados %s arquivos de backup no diretório %s" % (date, number_of_files, directory) purge_dir(directory) else: print "%s - Foram encontrados %s arquivos de backup nenhum será removido %s" % (date, number_of_files, directory) def checkfile(filename): filestats = os.stat(filename) # pega informaçoes do arquivo if time.time() - filestats.st_mtime > 86400*7: # checa se o arquivo tem mais de 7 dias e remove caso positivo print "Removendo: %s" % (filename) os.remove(filename) def purge_dir(path): dirList = os.listdir(path) # Lista o diretório for filename in dirList: checkfile(os.path.join(path, filename)) # executa funcao checkfile. def backup(): database_list_command="mysql -u %s -p%s -h %s --silent -N -e 'show databases'" % (username, password, hostname) #lista databases for database in os.popen(database_list_command).readlines(): database = database.strip() if database == 'information_schema': continue if database == 'performance_schema': continue print "%s - Criando Backup database: %s" % (date, database) target_dir = "%s/%s" % (dest, database) if not os.path.exists(target_dir): print "%s - Criando novo diretório: %s" % (date, target_dir) os.makedirs(target_dir) filename = "%s/%s-%s.sql" % (target_dir, database, date) os.popen("mysqldump --max_allowed_packet=128M --single-transaction -u %s -p%s -h%s %s | bzip2 -c > %s.bz2" % (username, password, hostname, database, filename)) clear(target_dir) backup()
Acompanhar status de uma replicação MySQL
Gerar backups de banco de dados MySQL
Dump MySQL com relatório de logs por e-mail
Passkeys: A Evolução da Autenticação Digital
Instalação de distro Linux em computadores, netbooks, etc, em rede com o Clonezilla
Título: Descobrindo o IP externo da VPN no Linux
Armazenando a senha de sua carteira Bitcoin de forma segura no Linux
Enviar mensagem ao usuário trabalhando com as opções do php.ini
Instalando Brave Browser no Linux Mint 22
vídeo pra quem quer saber como funciona Proteção de Memória:
Encontre seus arquivos facilmente com o Drill
Mouse Logitech MX Ergo Advanced Wireless Trackball no Linux
Compartilhamento de Rede com samba em modo Público/Anônimo de forma simples, rápido e fácil
PC não liga no filtro de linha (3)
Desde que seja DDR3, posso colocar qualquer memória? (3)
Instalar sem formatar, pergunta meio boba. [RESOLVIDO] (7)
Curso gratuito Defesa de redes 10ª Maratona CiberEducação Cisco Brasil... (0)