Backup e recuperação de bancos de dados PostgreSQL ⋆ ALexHost SRL

Teste suas habilidades em todos os nossos serviços de hospedagem e ganhe 15% de desconto!

Utilizar o código no ato da compra:

Skills
21.11.2024

Backup e recuperação de bancos de dados PostgreSQL

A proteção de dados começa com uma solução de hospedagem confiável, especialmente para o gerenciamento de bancos de dados PostgreSQL críticos. Os Servidores Dedicados da AlexHost fornecem o ambiente ideal para hospedar o PostgreSQL, oferecendo um desempenho poderoso, acesso total à raiz e recursos avançados de segurança para garantir que seus dados estejam seguros e sempre acessíveis. Com a AlexHost, você pode integrar facilmente estratégias de backup como dumps SQL, backups de formato personalizado e recuperação point-in-time para manter a integridade do banco de dados e minimizar o tempo de inatividade.

O backup e a recuperação de bancos de dados PostgreSQL são essenciais para garantir a integridade dos dados e minimizar o tempo de inatividade em caso de perda de dados. Este guia o guiará pelas etapas de backup e restauração de bancos de dados PostgreSQL usando vários métodos.

1. Entendendo as opções de backup do PostgreSQL

O PostgreSQL oferece vários métodos para fazer backup de dados, incluindo:

  • SQL Dump: Esse método cria um script SQL de texto simples do banco de dados, que pode ser usado para recriar o banco de dados.
  • Dump de formato personalizado: Esse método cria um arquivo binário que pode ser compactado e é adequado para bancos de dados grandes.
  • Backup no nível do sistema de arquivos: Esse método envolve a captura de um instantâneo dos arquivos do banco de dados no disco, adequado para bancos de dados grandes, mas que requer mais conhecimento especializado.
  • Arquivamento contínuo e recuperação point-in-time (PITR): Esse método permite restaurar o banco de dados para um ponto específico no tempo.

2. Preparação para o backup

Antes de executar um backup, verifique se você tem os privilégios necessários. Você precisa ser um superusuário ou o proprietário do banco de dados do qual deseja fazer o backup.

3. Como fazer backup de um banco de dados PostgreSQL

Método 1: usando o pg_dump

O utilitário pg_dump permite que você crie um backup do seu banco de dados.

Etapa 1: abrir um terminal

Acesse seu servidor via SSH ou diretamente na máquina.

Etapa 2: Execute o comando pg_dump

Para criar um dump SQL de um banco de dados, use o seguinte comando:

pg_dump -U nome_de_usuário -W -F p nome_do_banco_de_dados > arquivo_de_backup.sql
  • -U nome de usuário: especifique o nome de usuário do PostgreSQL.
  • -W: Solicita a senha.
  • -F p: Especifique o formato (script SQL simples).
  • database_name: O nome do banco de dados do qual você deseja fazer backup.
  • backup_file.sql: O nome do arquivo de saída para o backup.
Exemplo:
pg_dump -U postgres -W -F p meu_banco_de_dados > meu_banco_de_dados_backup.sql

Método 2: Usando o pg_dumpall

Se você quiser fazer o backup de todos os bancos de dados na instância do PostgreSQL, poderá usar o pg_dumpall:

pg_dumpall -U nome de usuário -W > all_databases_backup.sql

4. Como fazer backup usando o formato personalizado

Para criar um backup em formato personalizado, use a opção -F c com o pg_dump:

pg_dump -U username -W -F c database_name > backup_file.dump

Esse formato facilita a restauração e a compactação.

5. Como restaurar um banco de dados PostgreSQL

Método 1: Restaurando a partir do SQL Dump

Para restaurar um banco de dados a partir de um dump SQL, use o comando psql:

psql -U nome de usuário -d nome_do_banco_de_dados -f arquivo_de_backup.sql
  • -d nome_do_banco_de_dados: o nome do banco de dados em que você deseja restaurar os dados.
  • backup_file.sql: O caminho para o arquivo de despejo SQL.

Método 2: Restaurar a partir do formato personalizado

Para obter um dump de formato personalizado, use o comando pg_restore:

pg_restore -U nome_de_usuário -d nome_do_banco_de_dados backup_file.dump
  • Você pode usar a opção -C para criar o banco de dados antes da restauração, caso ele não exista.

6. Uso do arquivamento contínuo e da recuperação pontual (PITR)

Para usuários avançados, o PostgreSQL permite o arquivamento contínuo, o que requer a configuração do WAL (Write-Ahead Logging). Esse método envolve:

  1. Configurar o arquivamento WAL: Modificar o arquivo postgresql.conf para habilitar o arquivamento WAL:
    archive_mode = on archive_command = ‘cp %p /path/to/archive/%f’
  2. Execução de backups básicos: Use pg_basebackup para fazer um backup completo do banco de dados.
  3. Restauração a partir de arquivos WAL: Você pode restaurar o banco de dados para um ponto específico no tempo usando o backup básico e os arquivos WAL arquivados.

7. Conclusão

Fazer backups regulares dos bancos de dados PostgreSQL é vital para a proteção e recuperação de dados. Seguindo os métodos descritos neste guia, você pode criar backups e restaurar seus bancos de dados com eficiência quando necessário. A implementação de uma estratégia sólida de backup garantirá a integridade de seus dados e minimizará o tempo de inatividade em caso de perda de dados.

Teste suas habilidades em todos os nossos serviços de hospedagem e ganhe 15% de desconto!

Utilizar o código no ato da compra:

Skills