Atualizar backup

This commit is contained in:
2025-03-24 12:07:57 -03:00
parent f9532a0cb2
commit 5889537299

277
backup
View File

@@ -2,165 +2,168 @@
# ┌──────────────────────────────────────────────────────────┐
# │ Author: Bruno.Tosta │
# │ Desc: Realiza o backup do banco de dados │
# ──────────────────────────────────────────{ CONFIGURACAO }┘
VERSAO="2.1"
# ├──────────────────────────────────────────────────────────
option='N' # │
# ├ "D" = Desligar |
# ├ "R" = Reiniciar |
# ├ "N" = Nada |
config='/etc/openerp-server.conf' # |
origem='/backup/postgres' # |
raiz='/backup' # |
destino='backup:' # |
# └─────────────────────────────────────────{ CONFIGURACOES }┘
VERSAO="4.0"
FINALIZAR='0'
# "0" = Finalizar | "1" = Reiniciar | "2" = Desligar
# ┌──────────────────────────────────────────────────────────┐
# └─────────────────────────────────────────────{ VARIAVEIS }┘
REPOSITORIO='download.sigsolucoes.net.br/public/Tosta/ERP'
DIR_ORIGEM='/backup/diario/Dropbox'
DIR_DESTINO='backup:'
DIRETORIO=$(date '+%A')
VERDE='\033[32;1m'
AMARELO='\033[33;1m'
VERMELHO='\033[31;1m'
RESET=$(tput 'sgr0')
LOG="$(date '+%m%Y')"
ARQUIVO_LOG="/tmp/rclone-$LOG.log"
MENSAGEM_LOG="#$(date '+%A, %d %B %Y')#"
MENU=" [ -OPÇÃO ]
-a Armazenamento
-c Checar
-C Configurar
-i Informacao
-l Listar
-s Sincronizar
-u Atualizar rclone
-U Atualizar script
-v Verificar
-V Versão do script
-h Ajuda deste menu"
# ┌──────────────────────────────────────────────────────────┐
# └─────────────────────────────────────────────────{ TESTE }┘
Testar(){
rclone --version 2>'/dev/null' | head -1 | grep -q 'rclone v1.67.0' && echo -e "${VERDE}Está atualizado! \n" $RESET || {
wget -q --show-progress -O '/tmp/rinstall' "$REPOSITORIO/instaladores/rclone"; chmod 755 '/tmp/rinstall'; /tmp/./rinstall
}
}
data=$(date '+%A')
log="/tmp/rclone-${data}.log"
total=$(echo "$(rclone about "${destino}" 2>'/dev/null' | awk '/Total:/ {print $2}' | sed 's/[a-zA-Z]*//g') * 1028" | bc 2>'/dev/null')
if tty -s; then
NORMAL=$(tput sgr0)
VERMELHO=$(tput setaf 1)
VERDE=$(tput setaf 2)
AMARELO=$(tput setaf 3)
fi
MENU='
-a ou --storage | Armazenamento
-c ou --check | Checar
-C ou --config | Configurar
-i ou --info | Informacao
-l ou --list | Listar
-s ou --sync | Sincronizar
-t ou --trash | Limpar lixeira
-u ou --update | Atualizar script
-v ou --version | Versão do script
-h ou --help | Ajuda deste menu
'
# ┌──────────────────────────────────────────────────────────┐
# └───────────────────────────────────────────────{ FUNCOES }┘
Configurar(){
rclone config;
configurar(){
clear && rclone config
}
Informacao(){
rclone about "$DIR_DESTINO";
informacao(){
rclone about "${destino}"
}
Listar(){
rclone tree "$DIR_DESTINO";
listar(){
rclone tree "${destino}"
}
Verificar(){
[ -e "$DIR_ORIGEM/" ] && echo "$DIR_ORIGEM/ existe" || {
mkdir -p "$DIR_ORIGEM/"
[ -e '/home/caixa/' ] && chown -R caixa:caixa '/backup'
[ -e '/home/sig' ] && chown -R sig:sig '/backup'
[ ! -e '/home/caixa/' ] && [ ! -e '/home/sig' ] && echo "${VERMELHO}Não existe usuário 'caixa' ou 'sig' neste computador${RESET}"
chmod -R 777 '/backup'
realizar(){
_fazerBackup(){
local __base=$(PGPASSWORD="${_password}" psql -U 'openerp' -l | awk '{ if ($3 == "openerp") print $1 }' | head -${i} | tail -1)
printf "\n${VERDE}Quantidade: ${i}/${_amount} \nBase: ${__base} \n${NORMAL}"
PGPASSWORD="${_password}" pg_dump -h 'localhost' -p '5432' --role 'openerp' -U 'openerp' -F 'custom' -b -v -T 'logs_logs' -T 'ir_attachment' -T 'logs_detalhe' -T 'ecf_exportar_osv_id_seq' -f "${_file}/${__base}-${data}.dump" "${__base}"
}
}
Realizar(){
SENHA=$(grep db_password '/etc/openerp-server.conf' | awk '{print $3}')
QUANTIDADE=$(PGPASSWORD="$SENHA" psql -U 'openerp' -l | awk '{ if ($3 == "openerp") print $1 }' | wc -l)
cd "$DIR_ORIGEM" && rm -rf "$DIRETORIO.tar.gz"
mkdir $DIRETORIO
for ((N=1; N < $(($QUANTIDADE+1)); N++)) do
BASE=$(PGPASSWORD="$SENHA" psql -U 'openerp' -l | awk '{ if ($3 == "openerp") print $1 }' | head -$N | tail -1)
printf "\n${VERDE}Quantidade: $N \nBase: $BASE \n${RESET}"
PGPASSWORD="$SENHA" pg_dump -h 'localhost' -p '5432' --role 'openerp' -U 'openerp' -F 'custom' -b -v -T 'logs_logs' -T 'ir_attachment' -T 'logs_detalhe' -T 'ecf_exportar_osv_id_seq' -f "$DIR_ORIGEM/$DIRETORIO/$BASE.dump" "$BASE"
local _password=$(grep db_password "$config" | awk '{print $3}')
local _amount=$(PGPASSWORD="${_password}" psql -U 'openerp' -l | awk '{ if ($3 == "openerp") print $1 }' | wc -l)
local _file=$(mktemp -d '/tmp/XXXXXXXXXX')
local _user=$(id -u '1000')
rm -f "${origem}/${data}.tar.gz"
for ((i=1; i < $(($_amount+1)); i++)) do
_fazerBackup
done
tar cfvz "$DIRETORIO.tar.gz" "$DIRETORIO" && chmod 777 "$DIRETORIO.tar.gz"; rm -rf "$DIRETORIO"
(cd "${_file}" && tar cfvz "${origem}/${data}.tar.gz" ./*.dump \
&& chown -R "${_user}":"${_user}" "${raiz}" \
&& chmod -R 755 "${raiz}")
}
HealthCheck(){
ESPACO=$(du -sm "$DIR_ORIGEM/$DIRETORIO.tar.gz" | awk '{print $1}')
[[ "$ESPACO" -gt 3 ]] && echo -e "\n${VERDE}O backup foi concluído com sucesso. \n${RESET}" || {
printf "\n${VERMELHO}O backup do banco de dados não foi realizado, verifique os parametros. \n${RESET}"; exit 1
healthCheck(){
local _verify=$(du -sm "${origem}/${data}.tar.gz" | awk '{print $1}')
[ "${_verify}" -gt 1 ] && echo -e "\n${VERDE}O backup foi concluído com sucesso. \n${NORMAL}" \
|| { printf "\n${VERMELHO}O backup do banco de dados não foi realizado, verifique os parametros. \n${NORMAL}"; exit 1; }
}
gerenciar(){
_removerExcesso(){
local __antigo=$(ls -rt "${origem}/" | head -1)
echo -e "${AMARELO}Removendo o arquivo ${__antigo} devido ao excesso de uso do espaço em disco.${NORMAL}"
rm "${origem}/${__antigo}" && echo -e "${VERDE}Arquivo ${__antigo} removido com sucesso. \n${NORMAL}"
}
Gerenciar(){
TOTAL=$(echo "$(rclone about "$DIR_DESTINO" | awk '{print $2}'| head -1) * 1028" | bc)
while true; do
USADO=$(du -sm "$DIR_ORIGEM/" | awk '{print $1}')
[ "$USADO" -gt "$TOTAL" ] && {
ANTIGO=$(ls -rt "$DIR_ORIGEM/" | head -1)
echo -e "${AMARELO}Removendo o arquivo $ANTIGO devido ao excesso de uso do espaço em disco.${RESET}"
rm "$DIR_ORIGEM/$ANTIGO" && echo -e "${VERDE}Arquivo $ANTIGO removido com sucesso. \n${RESET}"
} || {
echo "Arquivos cabem no diretório."; break
}
local __usado=$(du -sm "${origem}" | awk '{print $1}')
[ "${__usado}" -gt "${total}" ] && _removerExcesso \
|| { echo -e "${VERDE}Espaço suficiente no diretório.\n${NORMAL}"; break; }
done
}
Sincronizar(){
rclone -vP delete --delete-excluded "$DIR_ORIGEM/" "$DIR_DESTINO" --log-file="$ARQUIVO_LOG"
rclone -vP cleanup --progress "$DIR_DESTINO" --log-file="$ARQUIVO_LOG"
rclone -vP sync --progress "$DIR_ORIGEM/" "$DIR_DESTINO" --log-file="$ARQUIVO_LOG"
sincronizar(){
local _lixeira=$(echo "$(rclone about "backup:" 2>'/dev/null' | awk '/Trashed:/ {print $2}' | sed 's/[a-zA-Z]*//g') * 1028" | bc | sed 's/\..*//')
[ "${_lixeira}" -gt '0' ] && limparLixeira
rclone -vP sync --delete-excluded --delete-before --drive-use-trash=false --progress "${origem}/" "${destino}" --log-file="${log}"
}
Validar(){
tail "$ARQUIVO_LOG" | grep "ERROR"; [ ! $? -eq 0 ] && echo -e "\n${VERDE}Sincronismo concluído com sucesso. \n${RESET}" || {
echo -e "\n${VERMELHO}Erros encontrados. Verifique o arquivo $ARQUIVO_LOG. \n${RESET}"
limparLixeira(){
rclone cleanup "${destino}" && sleep 5
}
validar(){
tail "${log}" | grep "ERROR"; [ ! $? -eq 0 ] && \
echo -e "\n${VERDE}Sincronismo concluído com sucesso. \n${NORMAL}" \
|| echo -e "\n${VERMELHO}Erros encontrados. Verifique o arquivo ${log}. \n${NORMAL}"
}
Checar(){
DATA_ORIGEM=$(ls $DIR_ORIGEM/*.tar.gz -tl --time-style="+%Y-%m-%d" | awk '{print $6}')
DATA_DESTINO=$(rclone lsl "$DIR_DESTINO" | awk '{print $2}')
[ "$DATA_ORIGEM" = "$DATA_DESTINO" ] && echo -e "${VERDE}O backup está sendo feito normalmente \n${RESET}" || {
echo -e "${VERMELHO}O backup está defasado \n${RESET}"
checar(){
local _data_origem=$(ls ${origem}/*.tar.gz -tl --time-style="+%Y-%m-%d" | awk '{print $6}')
local _data_destino=$(rclone lsl "${destino}" | awk '{print $2}')
[ "${_data_origem}" = "${_data_destino}" ] && \
echo -e "${VERDE}O backup está sendo feito normalmente \n${NORMAL}" \
|| echo -e "${VERMELHO}O backup está defasado \n${NORMAL}"
}
armazenamento(){
local _usado=$(du -sm "${origem}/" | awk '{print $1}')
[ "${total}" -lt "${_usado}" ] && gerenciar \
|| echo -e "${VERDE}O drive tem espaço suficiente para a realização do backup \n${NORMAL}"
}
Armazenamento(){
T=$(echo "$(rclone about $DIR_DESTINO | awk '{print $2}'| head -1) * 1028" | bc)
U=$(du -sm "$DIR_ORIGEM/" | awk '{print $1}')
[ "$T" -lt "$U" ] && Gerenciar || {
echo -e "${VERDE}Espaço disponível no drive é suficiente para a realização do backup \n${RESET}"
}
}
Backup(){
Verificar && Realizar && HealthCheck
rclone config show 2>'/dev/null' | grep -q '^\[.*\]' && {
Gerenciar && Sincronizar && Validar && Checar
} || {
echo -e "${AMARELO}Backup feito apenas localmente \n${RESET}"; exit 0
}
backup(){
[ -e "${origem}" ] && echo "${origem}/ existe" \
|| { mkdir -p "${origem}" && echo "${origem}/ criada"; }
realizar && healthCheck \
&& rclone config show 2>'/dev/null' | grep -q '^\[.*\]' && (gerenciar && sincronizar && validar && checar) \
|| (echo -e "${AMARELO}Backup feito apenas localmente \n${NORMAL}")
case ${option} in
D) poweroff
;;
R) reboot
;;
N) echo -e "${VERDE}Finalizado \n${NORMAL}"
;;
*) exit
;;
esac
}
# ┌──────────────────────────────────────────────────────────┐
# └─────────────────────────────────────────────{ PRINCIPAL }┘
Finaliza(){
case "$FINALIZAR" in
2) sudo shutdown -h now ;;
1) sudo reboot ;;
0) exit 0 ;;
esac
}
[ -z "$1" ] && {
Backup; Finaliza
} || {
while [ -n "$1" ]; do
case "$1" in
-a) clear; echo -e "${AMARELO}Armazenamento da aplicação \n${RESET}"; Armazenamento; exit
;;
-c) clear; echo -e "${AMARELO}Checando o rclone \n${RESET}"; Checar; exit
;;
-C) clear; echo -e "${AMARELO}Configuração do rclone \n${RESET}"; Configurar; clear; exit
;;
-i) clear; echo -e "${AMARELO}Informações de armazenamento \n${RESET}"; Informacao; exit
;;
-l) clear; echo -e "${AMARELO}Listar arquivos e diretórios \n${RESET}"; Listar; exit
;;
-s) clear; echo -e "${AMARELO}Sincronizar backups \n${RESET}"; Sincronizar; exit
;;
-u) clear; echo -e "${AMARELO}Atualização do rclone \n${RESET}"; Testar; exit
;;
-U) clear; sudo su -s '/bin/bash' -c 'hub -B'; exit
;;
-v) clear; echo -e "${AMARELO}Verificação de arquivos \n${RESET}"; Verificar; exit
;;
-V) clear; echo -e "\n ${VERDE}A versão do script é $VERSAO${RESET}"; exit
;;
-h|--help) echo -e "\n $MENU \n${RESET}"; exit
;;
*) echo -e "${VERMELHO}Opção inválida. $MENU \n${RESET}"; exit 1
;;
[ ! "$(id -u)" = '0' ] && echo -e "${VERMELHO}É necessário executar como root para continuar \n${NORMAL}" && exit \
|| [ -z "${1:-}" ] && backup \
|| while [ -n "${1:-}" ]; do
case "${1}" in
-a|--storage) echo -e "${AMARELO}Armazenamento da aplicação \n${NORMAL}" && armazenamento \
&& exit;;
-c|--check) echo -e "${AMARELO}Checando o rclone \n${NORMAL}" && checar \
&& exit;;
-C|--config) echo -e "${AMARELO}Configuração do rclone \n${NORMAL}" && configurar \
&& exit;;
-i|--info) echo -e "${AMARELO}Informações de armazenamento \n${NORMAL}" && informacao \
&& exit;;
-l|--list) echo -e "${AMARELO}Listar arquivos e diretórios \n${NORMAL}" && listar \
&& exit;;
-s|--sync) echo -e "${AMARELO}Sincronizar backups \n${NORMAL}" && sincronizar \
&& exit;;
-t|--trash) echo -e "${AMARELO}Limpando lixeira \n${NORMAL}" && limparLixeira \
&& exit;;
-u|--update) sudo su -s '/bin/bash' -c 'hub -B' \
&& exit;;
-v|--version) echo -e "${VERDE}A versão do script é ${VERSAO}${NORMAL}" \
&& exit;;
-h|--help) echo -e "${VERMELHO}\n [ OPÇÃO ]\n ${MENU}${NORMAL}" \
&& exit;;
*) echo -e "${VERMELHO}\n [ OPÇÃO INVÁLIDA ]\n ${MENU}${NORMAL}" \
&& exit 1;;
esac
done
}
# └──────────────────────────────────────────────────────────┘