Sugestão de script para automatizar o backup do banco de dados em um conta do mega.io.
Exemplo de configuração no cron (diariamente as 03:00 AM)
0 3 * * * /opt/backup_mega.sh >> /var/log/backup_mega.log 2>&1
Script base, ajustar as variáveis com os dados de acesso corretos.
#!/bin/bash
DB_HOST="localhost"
DB_USER="root"
DB_PASS=""
MEGA_EMAIL="seu@email.com"
MEGA_PASS="sua_senha"
#------------------------------------------------------------------------------------------
# Não mexer abaixo deste ponto a não ser que saiba exatamente o que esteja fazendo
#------------------------------------------------------------------------------------------
DATABASES=("vigo_erp" "mikrotik_erp" "mail")
TIMESTAMP=$(date +"%Y%m%d_%H%M%S")
BACKUP_FILE="backup_${TIMESTAMP}.sql.gz"
TMP_DIR=$(mktemp -d)
TMP_FILE="${TMP_DIR}/${BACKUP_FILE}"
DUMP_ARGS=(
-h "${DB_HOST}"
-u "${DB_USER}"
-p"${DB_PASS}"
--default-character-set=latin1
--quick
--force
--hex-blob
--max-allowed-packet=200M
--single-transaction
--routines
--triggers
--databases "${DATABASES[@]}"
)
cleanup() {
[ -n "${TMP_DIR}" ] && [ -d "${TMP_DIR}" ] && rm -rf "${TMP_DIR}"
}
trap cleanup EXIT
echo "[$(date '+%Y-%m-%d %H:%M:%S')] Iniciando dump dos bancos de dados..."
if ! mysqldump "${DUMP_ARGS[@]}" | gzip > "${TMP_FILE}"; then
echo "[ERRO] Falha ao gerar o dump." >&2
exit 1
fi
echo "[$(date '+%Y-%m-%d %H:%M:%S')] Dump gerado: ${BACKUP_FILE} ($(du -sh "${TMP_FILE}" | cut -f1))"
echo "[$(date '+%Y-%m-%d %H:%M:%S')] Enviando para o MEGA..."
if ! mega-login "${MEGA_EMAIL}" "${MEGA_PASS}"; then
echo "[ERRO] Falha ao autenticar no MEGA." >&2
exit 1
fi
if ! mega-put "${TMP_FILE}" "/"; then
echo "[ERRO] Falha ao enviar para o MEGA." >&2
exit 1
fi
echo "[$(date '+%Y-%m-%d %H:%M:%S')] Backup enviado com sucesso: ${MEGA_DIR}/${BACKUP_FILE}"
mega-logout