Pular para o conteúdo

Autovacuum do PostgreSQL

Dica publicada em Banco de Dados / Postgres
Caio Ferreira Dias caio
Hits: 22.796 Categoria: Banco de Dados Subcategoria: Postgres
  • Indicar
  • Impressora
  • Denunciar
O Viva o Linux depende da receita de anúncios para se manter. Ative os cookies aqui para nos patrocinar.
Não conseguimos carregar os anúncios. Se usa bloqueador, considere liberar o Viva o Linux para nos patrocinar.

Autovacuum do PostgreSQL

Pessoal, sou dba de uma empresa que usa PostgreSQL e temos várias conexões simultâneas, então vou compartilhar com vocês uma dica que uso aqui referente ao autovacuum do Postgres, onde estava me gerando dor de cabeça.

Primeiramente desabilite o autovacuum no postgresql.conf colocando autovacuum = off. Depois crie um script do para fazer o vacuum full.

# nano vacuum.sh

Coloque o seguinte conteúdo.

#!/bin/bash
su - postgres -c "/usr/bin/vacuumdb --d banco --full --analyze -U postgres
O Viva o Linux depende da receita de anúncios para se manter. Ative os cookies aqui para nos patrocinar.
Não conseguimos carregar os anúncios. Se usa bloqueador, considere liberar o Viva o Linux para nos patrocinar.

Salve e mude o arquivo para executável:

# chmod +x vacuum.sh

Edite o contrab para agendar o horário que será executado:

# nano /etc/crontab

Colocando a linha:

00 22 * * * root /local-script/vacuum_pg.sh

Salve! Pronto, todos os dias irá realizar o vacuum completo às 22:00.

O Viva o Linux depende da receita de anúncios para se manter. Ative os cookies aqui para nos patrocinar.
Não conseguimos carregar os anúncios. Se usa bloqueador, considere liberar o Viva o Linux para nos patrocinar.

Ubuntu 11.04 - Placa wireless parou de funcionar com o kernel 2.6.39.x?

Resolvendo waiting ou idle transaction no PostgreSQL

Script Reindex PostgreSQL com envio de email de notificação

Verificar triggers desabilitadas no PostgreSQL

PostgreSQL 9.1 64 bits - Instalação no Debian Squeeze

Instalação e configuração do Postgresql + Pgadmin3 LocalHost no Fedora

Configurar Postgresql para conectar com senha criptografada

Evitando erros ao indexar campos timestamp em SQL

Instalar a última versão do PostgreSQL no Lunix mantendo atualizado

#1 Comentário enviado por hgporto em 14/08/2014 - 13:36h
Caio, boa dica!
Só faltou fechar aspas (") no comando do script.
;)
Abs!
#2 Comentário enviado por BacamarteLinux em 07/07/2015 - 20:21h
Em bases grandes isso vacuum full é inviável...

Contribuir com comentário

Entre na sua conta para comentar.