Restauração de backup Firebird a partir de um arquivo .7Z contendo um GBK

Publicado por G. Magalhaes (última atualização em 24/07/2018)

[ Hits: 2.625 ]

Download 6868.viva_restauracaodobackup.sh




Saudações a todos!

Script para restauração de backup Firebird a partir de um arquivo .7Z contendo um arquivo GBK que irá gerar um arquivo FDB. Sistema CentOS 7 32 Bits (sim, existem CentOS 7 32 bits) com Firebird 2.56 versão SuperServer.

Autor: AgOfEarth, submetido ao Viva o Linux - https://www.vivaolinux.com.br/ em 24 de julho de 2018.

Continuando o artigo:

http://www.vivaolinux.com.br/script/Backup-compactacao-verificacao-e-transferencia-de-arquivos/

Vamos, no CentOS 7 32 bits, através do Firebird Superserver, restaurar o backup de uma base de dados salva num local específico no Firebird SuperServer e novamente tudo será registrado em um LOG que fica na máquina e também enviado por email.

Pré-requisitos:

- CentOS 7 32 bits (espero publicar em breve um artigo de como instalar o desconhecido CentOS 32bits. Deve funcionar no 64 bits normalmente, mas não testei, faça-o por sua conta e risco)
- Firebird SuperServer (no CentOS 32 bits não é automática a instalação, já que o 32 bits não possui os repositórios padrões e isso também será abordado no artigo de instalação do sistema 32 bits)
- 7zip
- mail
- Samba

Ressalvas:

1) Usei este script por muito tempo e nunca tive nenhum problema e tentei cercar algumas eventuais mensagens de erro/alertas do Firebird, mesmo assim use-o por sua conta e risco, se der algum problema não tenho culpa não ;-) ! Claro nunca se deve testar na base de produção antes de ter certeza do que está fazendo.

2) Lembre-se de adicionar o script ao seu crontab. No meu caso usei, como root o comando "crontab -e". Ao tentar editar o /etc/crontab não deu certo, mas não procurei entender o porquê.No terminal, como root, digite "crontab -e" e insira algo do tipo:

00 22 * * MON-SAT /root/vivaobackup.sh

Neste caso, todos os dias às 22 horas em ponto (00) de todos os dias (*) de todos os meses (*) de segunda (MON) a sábado (SAT) executo o script que está no /root/.

3) Este script funciona "em série" com o script citado acima, portanto o horário que deve constar no crontab deve levar em conta que todo o processo do outro script esteja terminado, caso contrário haverá erro devido ao fato do back-up não existir ou ainda de estar em uso pelo outro script!

4) Gostaria de agradecer a todos de todas as comunidade de onde tirei alguma informação e se não cito uma bibliografia em particular, deve-se ao fato de que estou criando este tipo de script a bastante tempo antigamente para o CENTOS 6.5 e desta vez apenas atualizei o script.

Abraços a todos.

  



Esconder código-fonte

#Script para restauração de backup Firebird a partir de um arquivo .7Z contendo um arquivo GBK que irá gerar um  arquivo FDB. Sistemas Centos 7 32 Bits (sim, existem Centos 7 32 bits) com Firebird 2.56 versão SuperServer.

#Autor AgOfEarth submetido ao Viva o Linux - https://www.vivaolinux.com.br/ em 24 de julho de 2018.

#Continuando o artigo: http://www.vivaolinux.com.br/script/Backup-compactacao-verificacao-e-transferencia-de-arquivos/, vamos, no Centos 7 32 bits através do Firebird Superserver, restaurar o back-up de uma base de dados salvada num local específica no Firebird SuperServer e novamente tudo será registrado em um LOG que fica na máquina e também enviado por email.

#Pre-Requisitos:
#- Centos 7 32 bits (espero publicar em breve um artigo de como instalar o desconhecido Centros 32bits. Deve funcionar no 64 bits normalmente, mas não testei, faça-o por sua conta e risco.)
#- Firebird SuperServer ( no Centos 32 bits não é automática a instalação já que o CENTOS 32 bits não possui os repositórios padrões e isso também será abordado no artigo de instalação do CENTOS 32 bits)
#- 7zip
#- mail
#- Samba

#Ressalvas: 

#1) Usei este script por muito tempo e nunca tive nenhum problema e tentei cercar algumas eventuais mensagens de erro/alertas do Firebird, mesmo assim use-o por sua conta e risco, se der algum problema não tenho culpa não ;-) ! Claro nunca se deve testar na base de produção antes de ter certeza do que está fazendo.

#2) Lembre-se de adicionar o script ao seu crontab. No meu caso usei, como root o comando "crontab -e". Ao tentar editar o /etc/crontab não deu certo, mas não procurei entender o porquê.No terminal, como root, digite "crontab -e" e insira algo do tipo:
# 00 22 * * MON-SAT /root/vivaobackup.sh
# Neste caso, todos os dias aas 22 horas em ponto (00) de todos os dias (*) de todos os meses (*) de segunda (MON) a sábado (SAT) executo o script que está no /root/.

#3) Este script funciona "em série" com o script citado acima, portanto o horário que deve constar no crontab deve levar em conta que todo o processo do outro script esteja terminado, caso contrário haverá erro devido ao fato do back-up não existir ou ainda de estar em uso pelo outro script!

#4) Gostaria de agradecer a todos de todas as comunidade de onde tirei alguma informação e se não cito uma bibliografia em particular, deve-se ao fato de que estou criando este tipo de script a bastante tempo antigamente para o CENTOS 6.5 e desta vez apenas atualizei o Script.


#!/bin/bash
modo_teste=0

#No meu caso,  o arquivo de backup é muito grande e sempre obedece uma regra específica, portanto tenho como localizá-lo, mas é útil poder apontar para um arquivo com nome diferente. Claro que ele deverá estar compactado em 7z e lá dentro deverá ser um GBK com o mesmo prefixo. Abaixo procure a linha que contenha o teste: "$modo_teste -eq 0"


INICIO=`date +%Y/%m/%d-%H:%M:%S`

#===================== VERIFICA A EXISTENCIA DE ARQUIVO DE LOG, SE EXISTE É REMOVIDO=======================================

if [ -e /root/`date +%Y-%m-%d`.txt ];
then
   rm -rf /root/`date +%Y-%m-%d`.txt
fi
#===================== FIM VERIFICA A EXISTENCIA DE ARQUIVO DE LOG, SE EXISTE É REMOVIDO =======================================
LOG=/root/`date +%Y-%m-%d`.txt
LOG_temp=/root/log_temp.txt

ANO=`date +%Y`
MES=`date +%m`
DIA=`date +%d` 
DIA_SEMANA=`date +%w`
case $DIA_SEMANA in
0) DIA_SEMANA='Domingo';
;;
1) DIA_SEMANA='Segunda';
;;
2) DIA_SEMANA='Terca';
;;
3) DIA_SEMANA='Quarta';
;;
4) DIA_SEMANA='Quinta';
;;
5) DIA_SEMANA='Sexta';
;;
6) DIA_SEMANA='Sabado';
;;
esac

#Procurando onde o 7zip foi instalado... lembrando, fiz este script para o CENTOS.

if [ -e /usr/bin/7z ]
then
   compactador=1
else
   if [ -e /usr/bin/7za ]
   then
      compactador=2
   else
      compactador=3
   fi
fi

# Sempre testemos antes...
# Neste modo teste podemos pegar o back-up de uma base pequena tal a employee.fdb que já vem no firebird
# No meu caso este arquivo fica em: /var/lib/firebird/data/employee.fdb
# Gere o backup dele e compacte em 7z para que o script o encontre

if [ $modo_teste -eq 0 ]
then
prefixo=`echo $ANO$MES$DIA'Bk'$DIA_SEMANA`
else
prefixo=`echo 'NOME_PREFIXO_DE_TESTE'`
fi

echo -e "prefixo: $prefixo" >> $LOG

arquivo_original_7z=`echo $prefixo'.7z'`
echo -e "arquivo_original_7z: $arquivo_original_7z" >> $LOG
pasta_arquivo_original_7z=`echo '/bk/tmp_7z/'`
echo -e "pasta_arquivo_original_7z: $pasta_arquivo_original_7z" >> $LOG
caminho_arquivo_original_7z=`echo $pasta_arquivo_original_7z$arquivo_original_7z`
echo -e "caminho_arquivo_original_7z: $pasta_arquivo_original_7z$arquivo_original_7z" >> $LOG
pasta_final_arquivo_original_7z=`echo '/bk/'`
echo -e "pasta_final_arquivo_original_7z: $pasta_final_arquivo_original_7z" >> $LOG
caminho_final_arquivo_original_7z=`echo $pasta_final_arquivo_original_7z$arquivo_original_7z`
echo -e "caminho_final_arquivo_original_7z: $caminho_final_arquivo_original_7z" >> $LOG



arquivo_intermediario_gbk=`echo $prefixo'.gbk'`
echo -e "arquivo_intermediario_gbk: $arquivo_intermediario_gbk" >> $LOG
pasta_arquivo_intermediario_gbk=`echo '/bk/'`
echo -e "pasta_arquivo_intermediario_gbk: $pasta_arquivo_intermediario_gbk" >> $LOG
caminho_arquivo_intermediario_gbk=`echo $pasta_arquivo_intermediario_gbk$arquivo_intermediario_gbk`
echo -e "caminho_arquivo_intermediario_gbk: $caminho_arquivo_intermediario_gbk" >> $LOG


arquivo_final_fdb=`echo 'NOME_EMPRESA_RESTAURADO.fdb'`
echo -e "arquivo_final_fdb: $arquivo_final_fdb" >> $LOG
pasta_arquivo_final_fdb=`echo '/nfd5/'`
echo -e "pasta_arquivo_final_fdb: $pasta_arquivo_final_fdb" >> $LOG
caminho_arquivo_final_fdb=`echo $pasta_arquivo_final_fdb$arquivo_final_fdb`
echo -e "caminho_arquivo_final_fdb: $caminho_arquivo_final_fdb" >> $LOG

#=================== PARANDO SERVIÇOS ANTES DE COMEÇAR A RESTAURACAO DO BACK-UP ===============================================================
#=================== FALTA COLOCAR COMANDOS PARA VERIFICAR ERRO AO SE PARA CADA UM DESTES SERVIÇOS E ENVIO DE MENSAGEM ATRAVÉS DE LOG
systemctl start firebird-superserver
echo -e "`date +%H:%M:%S` Inciciando restauracao do back-up do NOME_EMPRESA_RESTAURADO.fdb - $DIA/$MES/$ANO, $DIA_SEMANA-feira, no servidor 123.123.123.70" >> $LOG
systemctl stop smb
echo -e "`date +%H:%M:%S` Compartilhamento parado......................: systemctl smb stop" >> $LOG
systemctl restart firebird-superserver
echo -e "`date +%H:%M:%S` Firebird reiniciado..........................: systemctl restart firebird-superserver" >> $LOG
#=================== FIM PARANDO SERVIÇOS ANTES DE COMEÇAR RESTAURAÇÃO DO BACK-UP ===============================================================

   LOG_temp=/root/log_temp.txt
#=================== COLOCAR TESTE PARA VERIFICAR O TAMANHO DO ARQUIVO COM BASE NO ARQUIVO .GBK E / OU NA PRESENCA DE TEXTO NO ARQUIVO DE LOG DE ERRO NO 7z
if [ -e $caminho_arquivo_original_7z ];
then
   echo -e "`date +%H:%M:%S`Arquivo $arquivo_original_7z localizado.\nVerificando integridade do arquivo $arquivo_original_7z" >> $LOG
   echo -e "++++++++++++++++++++++++++LOG do UN7z+++++++++++++++++++++++++++++++" >> $LOG
   LOG_un7z=/root/log_un7z.txt
   echo -e "Achei $arquivo_original_7z e vou DEScompactar!" >> $LOG_temp
   
   
   
   if [ $compactador -eq 1 ]
   then
      7z e -aoa $caminho_arquivo_original_7z -o$pasta_arquivo_intermediario_gbk &> $LOG_un7z
      echo -e "[`date +%Y`/`date +%m`/`date +%d` - `date +%H`:`date +%M`:`date +%S`] 7z e -aoa $caminho_arquivo_original_7z -o$pasta_arquivo_intermediario_gbk &> $LOG_un7z" >> $LOG
   else
      if [ $compactador -eq 2 ]
      then
         7za x -aoa $caminho_arquivo_original_7z -o$pasta_arquivo_intermediario_gbk &> $LOG_un7z
         echo -e "[`date +%Y`/`date +%m`/`date +%d` - `date +%H`:`date +%M`:`date +%S`] 7za x -aoa $caminho_arquivo_original_7z -o$pasta_arquivo_intermediario_gbk &> $LOG_un7z" >> $LOG
      else
         echo -e "NAO FOI LOCALIZANDO NEM O COMPACTADOR 7Z NEM O 7ZA, INSTALE-O!!!" >> $LOG
      fi
   fi
   
   
   
   
   echo -e "Descompactei" >> $LOG_temp
   cat $LOG /root/log_un7z.txt > $LOG_temp
   rm -rf $LOG_un7z
   echo -e "++++++++++++++++++++++FIM DO LOG do UN7z++++++++++++++++++++++++++++" >> $LOG_temp
   rm -rf $LOG_un7z
   rm -rf /root/log_un7z.txt
   cat $LOG_temp > $LOG
   rm -rf $LOG_temp
   LOG_temp=/root/log_temp.txt
   ERRO_DESCOMPACTACAO=0
   mv $caminho_arquivo_original_7z $caminho_final_arquivo_original_7z
else
   echo -e "NAO FOI POSSIVEL VERIFICAR A INTEGRIDADE DO ARQUIVO $caminho_arquivo_original_7z POIS ELE NAO FOI LOCALIZADO! \n VERIFICAR ARQUIVO DE LOG: $LOG" >> $LOG
   ERRO_DESCOMPACTACAO=1
   systemctl restart smb
fi

if [ -e $caminho_arquivo_intermediario_gbk ] && [ $ERRO_DESCOMPACTACAO -eq 0 ];
then
echo -e "++++++++++++++++++++++++++LOG do UN7z+++++++++++++++++++++++++++++++" >> $LOG
   chmod 777 $caminho_arquivo_intermediario_gbk
   gbak -user SYSDBA -pass SEGREDO $caminho_arquivo_intermediario_gbk $caminho_arquivo_final_fdb -rep -c -v -G -p 8192 -fix_fss_metadata win1252 #&> $LOG_gbak

# Na linha foi comentado o comando "&> $LOG_gbak", pois caso contrário o LOG ficaria imenso!

   if [ $? -eq 0 ]
   then
      rm -rf $caminho_arquivo_intermediario_gbk
      chmod 777 $caminho_arquivo_final_fdb
      echo -e "restauracao do banco de dados concluida, removendo arquivo $arquivo_original_7z de $caminho_arquivo_original_7z" >> $LOG
   else
      echo -e "Erro no processo de restauracao o gbac nao conseguiu terminar ou terminou com erros. repita o procedimento!"
      systemctl restart smb
   fi
echo -e "++++++++++++++++++++++++++FIM LOG do UN7z+++++++++++++++++++++++++++++++" >> $LOG
else
   if [ "$ERRO_DESCOMPACTACAO" -eq 1 ];
   then
      echo -e "HOUVE UM ERRO NO PROCESSO DE DESCOMPACTACAO, PORTANTO, NAO HA ARQUIVO $arquivo_original_7z A SE VERIFICAR em $pasta_arquivo_intermediario_gbk ! \n VERIFICAR ARQUIVO DE LOG: $LOG" >> $LOG
      systemctl restart smb
      ERRO_RESTAURACAO=1
   fi
fi


#=================== INICIANDO SERVIÇOS APÓS RESTAURAÇÃO O BACK-UP ===============================================================
   echo -e "Reiniciando FIREBIRD E COMPARTILHAMENTO." >> $LOG
   systemctl restart firebird-superserver
   echo -e "`date +%H:%M:%S` Firebird reiniciado..........................: systemctl firebird-superserver start" >> $LOG
   echo -e "Reiniciando SAMBA E COMPARTILHAMENTO." >> $LOG
   systemctl restart smb
   echo -e "`date +%H:%M:%S` Compartilhamento Reiniciado..................: systemctl smb start" >> $LOG
#=================== FIM INICIANDO SERVIÇOS APÓS O BACK-UP ===========================================================
echo -e "FIM `date +%H:%M:%S`" >> $LOG

ASSUNTO="restauracao de Backup do $caminho_arquivo_final_fdb - $DIA/$MES/$ANO, $DIA_SEMANA-feira, no servidor 123.123.123.70"
MENSAGEM="Assunto: $ASSUNTO \nEMAIL_FROM: $EMAIL_FROM \nEMAIL_TO $EMAIL_TO"
rm -rf /root/log_temp.txt
tr  X < $LOG | mail -s "$ASSUNTO" -cEMAIL1@DOMINIO.NOME_EMPRESA.br,EMAIL2@DOMINIO.NOME_EMPRESA.br EMAIL3@DOMINIO.NOME_EMPRESA.br


Scripts recomendados

DriveTool.sh: um script para cópia rápida e segura de arquivos para unidades flash USB

Script de Backup de Sistema

Backup Máquina do Tempo com Rsync

Backup, Recuperação e Chroot

Backup e envio do arquivo + md5sum para o FTP da escolha do usuário


  

Comentários

Nenhum comentário foi encontrado.


Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts