Skip to content

Latest commit

 

History

History
24 lines (14 loc) · 2.9 KB

README.md

File metadata and controls

24 lines (14 loc) · 2.9 KB

NPK Backup

Um pequeno utilitário para automatizar a cópia de segurança de uma determinada pasta (por exemplo, cópias de segurança locais de bases de dados Filemaker, coleções de scripts e aplicações do Pythonista, etc.), criando arquivos zip individuais a partir de cada pasta principal na localização especificada e fazendo upload dos mesmos para a Dropbox. Os arquivos zip são automaticamente agrupados numa estrutura de pastas, organizada por anos, meses e dias.

O programa mantém um registo simples, por forma a nao repetir as tarefas de compressão e upload já realizadas. Em cada execução, são efetuadas cópias individuais de cada pasta nova, que ainda não conste nas cópias anteriores. Convém notar que não são copiadas pastas nem ficheiros previamente processados, mesmo que possam ter sido alterados entretanto.

Dependências

Esta aplicação é desenvolvida em Python 3.5 e requer, na versão atual, o(s) seguinte(s) módulo(s) externo(s):

  • dropbox (necessário para o utilitário NPK-Backup)
  • send2trash (necessário para o utilitário remove_old_archives.py)

O desenvolvimento e testes têm sido realizados em Mac e iOS (Pythonista 3), no entanto deverá ser bastante simples a adaptação para funcionar sem problemas em Windows ou Linux.

Como usar

Inicialmente, deverão ser especificadas no ficheiro app_settings.py as constantes relativas ao caminho dos ficheiros ou pastas de origem. Para a realização de cópias de segurança de bases de dados, é recomendável consultar a respetiva documentação, no sentido de verificar quais as pastas e ficheiros a copiar.

É também necessário registar a aplicação no site da Dropbox e configurar no ficheiro app_settings.py a token lá indicada.

Para iniciar a cópia, basta executar o ficheiro npk-backup.py com o interpretador Python 3.5 ou superior. Em sistemas operativos que suportem algum mecanismo de agendamento (cron, launchd, etc.), este script pode ser utilizado para a realização de cópias automatizadas, requerendo para tal a sua chamada a partir do serviço correspondente do sistema.

O ficheiro remove_old_archives.py é pequeno utilitário complementar ao utilitário NPK-Backup, que serve para automatizar a remoção de ficheiros de arquivo antigos na pasta especificada (a utilizar numa máquina onde estejam alojada a pasta de arquivo sincronizada com a Dropbox). Em cada execução, este programa apaga todas as pastas (e respetivos conteúdos) cuja data seja mais recente do que o número de dias indicado no ficheiro de configurações. Pressupõe a presença de uma estrutura de pastas organizada por anos, meses e dias, conforme explicado acima.

NOTA: Este script apaga de forma imediata e irreversível ficheiros e pastas, sem qualquer aviso prévio ao utilizador, pelo que existe risco de perda de dados. Recomenda-se por isso as devidas precauções e testes exaustivos antes de decidir utilizá-lo num contexto real.