Começaremos criando o diretório onde será guardado o source do postgresql e baixando o mesmo : # cd /opt/ Depois , descompactamos o source e compilamos: # tar xvzf postgresql-7.3.4.tar.gz Se tudo tiver dado certo , você vai estar com o postgresql instalado na sua maquina. Os binários vão estar instalados em /usr/bin/ as libs em /usr/lib/postgresql/ os docs em /usr/doc/postgresql/ as manpages em /usr/man. Assim , você não precisa adicionar nada no .bashrc do seu home ou mexer no profile global . Agora vamos adicionar o usuário e grupo para o postgresql poder rodar: # groupadd postgres Iniciando o postgresql: # su - postgres Se tudo estiver dado certo , voce poderá dar um ps ax e verá o postgresql rodando perfeitamente. Ex: $ ps ax Criando a database para o usuário postgres: $ createdb postgres Logando no banco para fazer as alterações: $ psql postgres Pronto , você já está logando no banco , agora vamos alterar a senha do usuário postgres: postgres=# alter user postgres with encrypted password 'sua-senha'; Pronto, você alterou a senha do administrador do banco que é o usuário postgres, mude a parte 'sua-senha' para uma senha de sua preferência . E não esqueça do ; no final , se não vai retornar um mensagem de erro . Agora vamos fazer algumas alterações no arquivo pg_hba.conf para ele sempre pedir senha quando alguém for logar no banco . Pois por padrão o postgresql não exige senha na hora de logar, e sendo assim qualquer usuário que tiver uma shell no sistema , consegue acesso total ao banco . Editando o arquivo pg_hba.conf que está em /var/lib/pgsql/ data altere as seguintes linhas no final do arquivo : local all all trust Estas linha libera todas as bases com permissão trust ( em localhost), a permissão trust da acesso as bases sem requisição de senha ( mesmo que o user tenha uma senha ). Troque as palavras trust por md5, deixando assim : local all all md5 Agora inicie o seu postgresql: $ pg_ctl stop -D /var/lib/pgsql/ data / -s -m fast Agora teste se o seu postgresql esta pedindo senha : $ psql postgres Pronto , agora o seu banco de dados está mais seguro , poi só quem vai logar nele é quem tiver senha . E isso vai lhe poupar umas boas noites de sono :) Para não ter que ficar digitando isso na manualmente , segue abaixo o script de inicialização, ele vem junto no pacote do source do postgresql, e está dentro do diretório crontrib/start-scripts. Mas como ele não atendia todas as minhas necessidades , por isso fiz as alterações que precisava. #! /bin/sh# chkconfig: 2345 98 02 # description: PostgreSQL RDBMS # This is an example of a start/stop script for SysV-style init, such # as is used on Linux systems. You should edit some of the variables # and maybe the 'echo' commands. # Place this file at /etc/init.d/postgresql (or # /etc/rc.d/init.d/postgresql) and make symlinks to # /etc/rc.d/rc0.d/K02postgresql # /etc/rc.d/rc1.d/K02postgresql # /etc/rc.d/rc2.d/K02postgresql # /etc/rc.d/rc3.d/S98postgresql # /etc/rc.d/rc4.d/S98postgresql # /etc/rc.d/rc5.d/S98postgresql # Or, if you have chkconfig, simply: # chkconfig --add postgresql # Proper init scripts on Linux systems normally require setting lock # and pid files under /var/run as well as reacting to network # settings, so you should treat this with care. # Original author: Ryan Kirkpatrick # Altered by: Cláudio Borges # $Header: /cvsroot/pgsql-server/contrib/start-scripts/linux,v 1.3 2001/07/30 14:52:42 momjian Exp $ ## EDIT FROM HERE # Installation prefix prefix=/usr # Data directory PGDATA="/var/lib/pgsql/ data " # Who to run pg_ctl as, should be "postgres". Salve este script como rc.postgresql no diretório /etc/rc.d/ depois adicione a permissão de execução chmod +x rc.postgresql. Depois é so adicionar o rc.postgresql no seu rc. local (faça isso com o usuário root): # chmod +x rc.postgresql Pronto , agora quando iniciar o seu micro , o postgresql será iniciado automáticamente . Espero ter ajudado alguém que tenha dúvidas em relação a este excelente banco de dados . |
|
|||||||||||||||||||||||||||||||||||||||||
Todos os direitos reservados:
DevMedia Group |